《数据清洗》 第六章 数据转换

目录

1.对文本文件personnel_data.txt中的数据进行数据粒度的转换,即将文本文件personnel_data.txt中字段为household_register的数据统一成省份,并输出到文本文件personnel_data_new.txt中

1.1转换granularity

1.1.1打开kettle工具,创建转换

1.1.2配置文本文件输入控件

1.1.3配置“字段选择”控件

1.1.4配置“排序记录”控件

1.1.5配置“表输入”控件

 1.1.6配置“记录集连接”控件

1.1.7配置“字段选择2”控件

 1.18配置“排序记录3”控件

 1.1.9配置“表输入2”控件

1.1.10配置“排序记录4”控件

1.1.11配置“记录集连接2”控件

1.1.12配置“字段选择3”控件

1.1.13配置“表输出”控件

1.2转换generalization_merge

1.2.1打开kettle工具,创建转换

1.2.2配置“表输入”控件

1.2.3配置“字段选择”控件

1.2.4配置“排序记录”控件

1.2.5配置“文本文件输入”控件

1.2.6配置“字段选择2”控件

1.2.7配置“排序记录2”控件

1.2.8配置“记录集连接”控件

1.2.9配置“字段选择3”控件

1.2.10配置“文本文件输出”控件

1.3作业generalization

1.3.1打开kettle工具,创建转换

1.3.2配置“转换”控件

1.3.3配置“转换2”控件

1.3.4运行作业generalization

1.3.5查看文本文件

2.对文本文件personnel_data_new.txt中字段为salary的数据进行商务规则计算,即计算每个人的月薪(以22天工作日计算),最终输出到文本文件personnel_data_monthly_salary.txt中

2.1打开kettle工具,创建转换

2.2配置“文本文件输入”控件

 2.3配置“增加常量”控件

2.4配置“计算器”控件

2.5配置“文本文件输出”控件

2.6 运行转换monthly_salary

2.7查看文本文件


 



1.对文本文件personnel_data.txt中的数据进行数据粒度的转换,即将文本文件personnel_data.txt中字段为household_register的数据统一成省份,并输出到文本文件personnel_data_new.txt中

1.1转换granularity

1.1.1打开kettle工具,创建转换

创建转换granularity,添加“表输入”、“字段选择”、“排序记录”、“记录集连接”、“过滤记录”、“空操作”、“表输出”控件及hop跳连接线

1.1.2配置文本文件输入控件

进入“文本文件输入”界面,将要抽取的personnel_data.txt文件添加到generalization转换中

进入“内容”选项卡,在分隔符处清除默认分隔符“;”,在分隔符处插入一个制表符;取消勾选“头部”复选框

进入“字段”选项卡,根据personnel_data.txt文件的内容添加对应的字段名称,并指定数据类型

完成文本文件输入控件的配置

1.1.3配置“字段选择”控件

 双击“字段选择”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称

1.1.4配置“排序记录”控件

双击“排序记录”控件,进入“排序记录”界面,并在“字段”框中添加字段household_register,对其进行排序

1.1.5配置“表输入”控件

双击“表输入”控件,进入“表输入”界面,单击【新建】按钮,配置数据库连接

 1.1.6配置“记录集连接”控件

双击“记录集连接”控件,进入“合并排序”界面,在“第一个步骤”处的下拉框中选择“排序记录”,“第二个步骤”处的下拉框中选择“排序记录2”;在“第一个步骤的连接字段”和“第二个步骤的连接字段”处添加连接字段,这里添加的连接字段是household_register和city;在“连接类型”处的下拉框选择连接类型,这里选择的LEFT OUTER,即左外连接

1.1.7配置“字段选择2”控件

双击“字段选择2”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称,这里添加的是记录集连接流中的字段household_register和pid

 1.18配置“排序记录3”控件

双击“排序记录 3”控件,进入“排序记录”界面,在“字段”框中添加字段pid,并对其进行排序

 1.1.9配置“表输入2”控件

双击“表输入2”控件,进入“表输入2”界面,单击【新建】按钮,配置数据库连接

1.1.10配置“排序记录4”控件

双击“排序记录 4”控件,进入“排序记录”界面,在“字段”框中添加字段pid,并对其进行排序

1.1.11配置“记录集连接2”控件

双击“记录集连接2”控件,进入“合并排序”界面,在“第一个步骤”处的下拉框中选择“排序记录3”,“第二个步骤”处的下拉框中选择“排序记录4”;在“第一个步骤的连接字段”和“第二个步骤的连接字段”处添加连接字段,这里添加的连接字段是pid;在“连接类型”处的下拉框选择连接类型,这里选择的LEFT OUTER,即左外连接

1.1.12配置“字段选择3”控件

双击“字段选择3”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称,这里添加的是记录集连接2流中的字段household_register和Provincial

1.1.13配置“表输出”控件

双击“表输出”控件,进入“表输出”配置界面,单击【新建】按钮,配置数据库连接

单击目标表右侧的【浏览】按钮,选择输出的目标表,即临时数据表personnel;勾选“指定数据库字段”的复选框。单击【输入字段映射】按钮,弹出“映射匹配”对话框,依次选中“源字段”选项框的字段和“目标字段”选项框的字段,再单击【Add】按钮,将一对映射字段添加至“映射”选项框中,若“源字段”选项框的字段和“目标字段”选项框的字段相同,则可以单击【猜一猜】按钮,让Kettle自动实现映射


1.2转换generalization_merge

1.2.1打开kettle工具,创建转换

创建一个转换generalization_merge,并添加“表输入”、“字段选择”、“排序记录”、“记录集连接”、“文本文件输出”控件

1.2.2配置“表输入”控件

双击“表输入”控件,进入“表输入”界面,单击【新建】按钮,配置数据库连接。在SQL框中编写SQL语句,用于查询数据表personnel中的数据

1.2.3配置“字段选择”控件

双击“字段选择”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称

1.2.4配置“排序记录”控件

双击“排序记录”控件,进入“排序记录”界面,并在“字段”框中添加字段id,对其进行排序

1.2.5配置“文本文件输入”控件

双击“文本文件输入”控件,进入“文本文件输入”界面,单击【浏览】按钮,选择要抽取personnel_data.txt文件;单击【增加】按钮,将要抽取的personnel_data.txt文件添加到generalization_merge转换中

 单击“内容”选项卡,在分隔符处清除默认分隔符“;”,单击【Insert TAB】按钮,在分隔符处插入一个制表符;取消勾选“头部”复选框

 单击“字段”选项卡,根据personnel_data.txt文件的内容添加对应的字段名称,并指定数据类型

1.2.6配置“字段选择2”控件

双击“字段选择2”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称 

1.2.7配置“排序记录2”控件

双击“排序记录”控件,进入“排序记录”界面,并在“字段”框中添加字段id,对其进行排序

1.2.8配置“记录集连接”控件

双击“记录集连接”控件,进入“合并排序”界面,在“第一个步骤”处的下拉框中选择“排序记录”,“第二个步骤”处的下拉框中选择“排序记录2”;在“第一个步骤的连接字段”和“第二个步骤的连接字段”处添加连接字段,这里添加的连接字段是id;在“连接类型”处的下拉框选择连接类型,这里选择的LEFT OUTER,即左外连接

1.2.9配置“字段选择3”控件

双击“字段选择3”控件,进入“字段选择”界面,在“选择和修改”选项卡处添加字段名称,并将字段household_register_new改为household_register

1.2.10配置“文本文件输出”控件

双击“文本文件输出”控件,进入“文本文件输出”界面,单击“文件名称”右侧的【浏览】按钮,选择输出文件,即文本文件personnel_data_new,单击“内容”选项卡,进入“内容”界面,清除分隔符处的默认分隔符,单击【插入Tab】按钮,插入Tab分隔符。并在编码处的下拉框选择“UTF-8”编码,单击“字段”选项卡,进入“字段”界面,添加要输出的字段

1.3作业generalization

1.3.1打开kettle工具,创建转换

新建作业,使用Kettle工具,创建一个作业generalization,并添加“Start”、“转换”、“成功”控件

1.3.2配置“转换”控件

双击“转换”控件,进入“转换”界面,单击“Transformations”处的【浏览】按钮,选择添加转换generalization

1.3.3配置“转换2”控件

双击“转换2”控件,进入“转换”界面,单击“Transformations”处的【浏览】按钮,选择添加转generalization_merge

1.3.4运行作业generalization

运行作业generalization,实现将文本文件personnel_data.txt中字段为household_register的数据统一成省份(直辖市),并输出到文本文件personnel_data_new.txt中

1.3.5查看文本文件

通过文本编辑器工具,查看文本文件personnel_data_new.txt中的数据



2.对文本文件personnel_data_new.txt中字段为salary的数据进行商务规则计算,即计算每个人的月薪(以22天工作日计算),最终输出到文本文件personnel_data_monthly_salary.txt中

2.1打开kettle工具,创建转换

使用Kettle工具,创建一个转换monthly_salary,并添加“文本文件输入”、“增加常量”、“计算器”、“文本文件输出”控件

2.2配置“文本文件输入”控件

双击“文本文件输入”控件,进入“文本文件输入”界面,单击【浏览】按钮,选择要抽取personnel_data_new.txt文件;单击【增加】按钮,将要抽取的personnel_data_new.txt文件添加到转换monthly_salary中

单击“内容”选项卡,在分隔符处清除默认分隔符“;”,单击【Insert TAB】按钮,在分隔符处插入一个制表符;取消勾选“头部”复选框

 单击“字段”选项卡,根据personnel_data.txt文件的内容添加对应的字段名称,并指定数据类型

 2.3配置“增加常量”控件

双击“增加常量”控件,进入“增加常量”界面,在字段框中添加一个字段days,并给定一个值22

2.4配置“计算器”控件

双击“计算器”控件,进入“计算器”界面,在字段框中添加一个字段monthly_salary,用于存储月薪,该字段是由字段days和salary进行相乘所得

2.5配置“文本文件输出”控件

双击“文本文件输出”控件,进入“文本文件输出”界面,单击“文件名称”右侧的【浏览】按钮,选择输出文件,即文本文件personnel_data_monthly_salary

单击“内容”选项卡,进入“内容”界面,清除分隔符处的默认分隔符,单击【插入Tab】按钮,插入Tab分隔符,并在编码处的下拉框选择“UTF-8”编码,单击“字段”选项卡,进入“字段”界面,添加要输出的字段

2.6 运行转换monthly_salary

单击转换工作区顶部的start按钮,运行转换monthly_salary,实现将文本文件personnel_data_new.txt中字段为salary的数据进行商务规则计算,即计算每个人的月薪(以22天工作日计算),最终输出到文本文件

2.7查看文本文件

通过文本编辑器工具,查看文本文件personnel_data_monthly_salary.txt中的数据

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 什么是数据清洗?为什么需要数据清洗数据清洗是指对数据进行预处理,包括处理缺失值、异常值、重复值、不一致值等问题,使数据更加准确、完整和可靠。 需要进行数据清洗的原因有: - 数据可能存在缺失、异常、重复或不一致等问题,影响数据分析的准确性和可靠性。 - 数据清洗能够帮助数据分析人员更好地理解数据,并发掘数据中的潜在价值。 - 数据清洗也是数据分析的第一步,为后续的数据处理和分析提供基础。 2. 数据清洗的步骤有哪些? 数据清洗的步骤一般包括以下几个方面: - 识别缺失值:使用isnull()函数或info()函数查看缺失值的情况。 - 处理缺失值:可以使用fillna()函数、interpolate()函数或删除缺失值的方法进行处理。 - 识别异常值:使用describe()函数或boxplot()函数查看数据分布情况,发现异常值。 - 处理异常值:可以使用分箱、截尾或删除异常值的方法进行处理。 - 识别重复值:使用duplicated()函数查看是否存在重复值。 - 处理重复值:可以使用drop_duplicates()函数进行处理。 - 识别不一致值:使用unique()函数查看数据的取值范围,发现不一致值。 - 处理不一致值:可以使用数据转换数据合并或删除不一致值的方法进行处理。 3. 缺失值存在的原因有哪些? 缺失值存在的原因有多种,主要包括以下几个方面: - 数据获取时的问题:例如数据收集不全、数据丢失、数据采集错误等。 - 数据处理时的问题:例如数据转换错误、数据合并时数据匹配不准确等。 - 数据存储时的问题:例如数据存储格式不一致、数据传输中的数据丢失等。 4. 如何处理缺失值? 处理缺失值的方法主要包括以下几个方面: - 删除:可以使用dropna()函数删除缺失值,但需要注意删除后可能会影响样本量,从而影响数据分析的结果。 - 插值:可以使用fillna()函数对缺失值进行填充,常用的插值方法有线性插值、多项式插值、样条插值等。 - 预测:可以使用机器学习模型对缺失值进行预测,例如线性回归、决策树等。 - 分组填充:可以根据数据的分组特征,对缺失值进行分组填充,例如使用平均值、中位数、众数等来填充。 5. 什么是异常值?如何处理异常值? 异常值是指在数据中出现的与其他数据显著不同的值,通常会对数据分析和模型建立造成不良影响。 处理异常值的方法主要包括以下几个方面: - 剔除:可以使用箱线图等方法判断和剔除异常值,但需要注意剔除后可能会影响样本量,从而影响数据分析的结果。 - 截尾:可以将异常值截尾替换成较大或较小的常数,例如将大于上限的值替换为上限,小于下限的值替换为下限。 - 分箱:可以将数据分为若干个区间,将落在同一个区间内的数据当做一个数值处理,例如将收入分为几个等级。 - 转换:可以使用对数、指数等函数对数据进行转换,使其符合正态分布或均匀分布,例如对数转换。 6. 如何识别和处理重复值? 识别重复值可以使用duplicated()函数,该函数返回一个布尔型的Series对象,表示每个元素是否为重复值。 处理重复值可以使用drop_duplicates()函数,该函数返回一个去重后的DataFrame对象。 7. 什么是数据不一致性?如何处理数据不一致性? 数据不一致性是指数据中出现的与其他数据不符的值,通常会对数据分析和模型建立造成不良影响。例如,一个人的年龄被记录为负数或超过了200岁。 处理数据不一致性的方法主要包括以下几个方面: - 数据转换:可以将数据进行转换,使其符合数据的取值范围,例如将年龄转换为出生年份。 - 数据合并:可以将不一致的数据进行合并,例如将出生日期和年龄合并为出生年份。 - 数据删除:可以删除不一致的数据,但需要注意删除后可能会影响样本量,从而影响数据分析的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值