五个简单有效的Python清理数据脚本分享

作者:佚名 时间:2021-11-01 08:08:50 

将 PDF 转换为 CSV

五个简单有效的Python清理数据脚本分享

在机器学习中,我们应该少一些“数据清理”,多一些“数据准备”。当我们需要从白皮书、电子书或其他PDF文档中抓取数据时,这个脚本为我节省了很多时间。

import tabula
#获取文件
pdf_filename = input ("Enter the full path and filename: ")
# 提取PDF的内容
frame = tabula.read_pdf(pdf_filename,  encoding = 'utf-8', pages='all')
#根据内容创建CSV文件
frame.to_csv('pdf_conversion.csv')

这是一种相对简单的快速提取数据的方法,可以在将数据导入机器学习数据库、Tableau或Count等工具。

合并 CSV 文件

许多系统会提供导出到CSV选项,但是没有办法在导出数据之前首先合并数据。这可能导致5个以上的文件导出到一个文件夹,这些文件包含相同的数据类型。该Python脚本通过获取这些文件)并将它们合并到一个文件中来解决这个问题。

from time import strftime
import pandas as pd
import glob
# 定义包含CSV文件的文件夹的路径
path = input('Please enter the full folder path: ')
#确保后面有一个斜杠
if path[:-1] != "/":
   path = path + "/"
#以列表形式获取CSV文件
csv_files = glob.glob(path + '*.csv')
#打开每个CSV文件并合并为一个文件
merged_file = pd.concat( [ pd.read_csv(c) for c in csv_files ] )
#创建新文件
merged_file.to_csv(path + 'merged_{}.csv'.format(strftime("%m-%d-%yT%H:%M:%S")), index=False)
print('Merge complete.')

最终输出将为您提供一个 CSV 文件,其中包含您从源系统导出的 CSV 列表中的所有数据。

从 CSV 文件中删除重复的行

如果您需要从CSV文件中删除重复的数据行,这可以帮助您快速执行清理操作。当机器学习数据集中拥有重复数据时,这会直接影响可视化工具或机器学习项目中的结果。

import pandas as pd
# 获取文件名
filename = input('filename: ')
#定义要检查是否重复的CSV列名
duplicate_header = input('header name: ')
#获取文件的内容
file_contents = pd.read_csv(filename)
# 删除重复的行
deduplicated_data = file_contents.drop_duplicates(subset=[duplicate_header], keep="last", inplace=True)
#创建新文件
deduplicated_data.to_csv('deduplicated_data.csv')

拆分 CSV 列

当从其他系统导出文件时,它有时会包含一列数据,而我们需要将其作为两列。

import pandas as pd
#获取文件名并定义列
filename = input('filename: ')
col_to_split = input('column name: ')
col_name_one = input('first new column: ')
col_name_two = input('second new column: ')
#将CSV数据添加到dataframe中
df = pd.read_csv(filename)
# 拆分列
df[[col_name_one,col_name_two]] = df[col_to_split].str.split(",", expand=True)
#创建新csv文件
df.to_csv('split_data.csv')

合并不同的数据集

假设您有一个帐户列表和与其关联的订单,并希望查看订单历史以及关联的帐户详细信息。一个很好的方法就是通过合并数据到一个CSV文件。

import pandas as pd
#获取文件名并定义用户输入
left_filename = input('LEFT filename: ')
right_filename = input('RIGHT filename: ')
join_type = input('join type (outer, inner, left, right): ')
join_column_name = input('column name(i.e. Account_ID): ')
#读取文件到dataframes
df_left = pd.read_csv(left_filename)
df_right = pd.read_csv(right_filename)
#加入dataframes
joined_data = pd.merge(left = df_left, right = df_right, how = join_type, on = join_column_name)
#创建新的csv文件
joined_data.to_csv('joined_data.csv')

最后

这些脚本可以有效帮助我们进行自动化清理数据,然后可以将清理后的数据加载到机器学习模型中进行处理。Pandas是操作数据的首选库,因为它提供了许多的选项。

来源:https://www.51cto.com/article/718638.html

标签:Python,Pandas,清理,数据
0
投稿

猜你喜欢

  • 在前女友婚礼上用python把婚礼现场的WIFI名称改成了

    2023-05-26 15:15:49
  • PL/SQL 类型格式转换

    2009-02-26 11:07:00
  • python中.format()方法使用详解

    2021-07-19 03:38:07
  • Python详解argparse参数模块之命令行参数

    2021-06-20 21:16:18
  • Python语法学习之进程的创建与常用方法详解

    2023-11-08 11:23:34
  • 用Css来制作一个漂亮的多选列表框

    2008-05-29 12:45:00
  • 瞎扯之Web导航

    2009-03-18 19:32:00
  • python应用文件读取与登录注册功能

    2023-04-17 17:04:03
  • 简化翻页提升可用性

    2009-03-28 11:52:00
  • Python三元运算实现方法

    2021-12-27 06:02:52
  • python自动化脚本安装指定版本python环境详解

    2022-08-14 11:31:46
  • python函数enumerate,operator和Counter使用技巧实例小结

    2022-08-09 07:02:32
  • Python Tkinter GUI编程实现Frame切换

    2023-05-08 07:36:28
  • 一篇文章教你掌握python数据类型的底层实现

    2023-06-01 03:41:14
  • Python Tkinter 简单登录界面的实现

    2021-01-10 20:45:03
  • Python lambda表达式filter、map、reduce函数用法解析

    2022-03-30 03:52:31
  • python自动化生成IOS的图标

    2021-04-26 19:16:34
  • ADO的错误码对应的含义

    2007-10-22 17:31:00
  • Python Django框架设计模式详解

    2021-01-16 12:52:40
  • 简单方法实现网页自动适应任何分辨率任何窗口大小

    2008-09-13 19:28:00
  • asp之家 网络编程 m.aspxhome.com