数据清洗第六章操作题

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

1.打开Kettle工具,新建转换使用Kettle工具,创建一个转换generalization,添加文本文件输入控件、表输入控件、字段选择控件、排序记录控件、记录集连接控件、表输出控件以及Hop跳连接线。
在这里插入图片描述2.配置文本文件输入控件,双击“文本文件输入”控件,进入“文本文件输入”界面,单击【浏览】按钮,选择要抽取personnel_data.txt文件;单击【增加】按钮,将要抽取的personnel_data.txt文件添加到generalization转换中。
在这里插入图片描述单击“内容”选项卡,在分隔符处清除默认分隔符“;”,然后单击【Insert TAB】按钮,在分隔符处插入一个制表符;取消勾选“头部”复选框。

在这里插入图片描述单击“字段”选项卡,根据personnel_data.txt文件的内容添加对应的字段名称,并指定数据类型。“字段”选项卡的配置。
在这里插入图片描述3.配置字段选择控件,双击“字段选择”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称,单击”确认“按钮完成配置。
在这里插入图片描述4.配置排序记录控件,双击“排序记录”控件,进入“排序记录”界面,并在“字段”框中添加字段household_register,对其进行排序,单击【确定】按钮,完成“排序记录”控件的配置。
在这里插入图片描述在这里插入图片描述5.配置表输入控件,双击“表输入”控件,进入“表输入”界面,单击【新建】按钮,配置数据库连接,配置完成后单击【确认】按钮。
在这里插入图片描述

7.配置记录集连接控件。双击“记录集连接”控件,进入“合并排序”界面,在“第一个步骤”处的下拉框中选择“排序记录”,“第二个步骤”处的下拉框中选择“排序记录2”;在“第一个步骤的连接字段”和“第二个步骤的连接字段”处添加连接字段,这里添加的连接字段是household_register和city;在“连接类型”处的下拉框选择连接类型,这里选择的LEFT OUTER,即左外连接,单击【确定】按钮,完成记录集连接控件的配置。

在这里插入图片描述8.配置字段选择2控件,双击“字段选择2”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称,这里添加的是记录集连接流中的字段household_register和pid,单击【确定】按钮,完成“字段选择2”控件的配置。
在这里插入图片描述9.配置排序记录3控件,双击“排序记录 3”控件,进入“排序记录”界面,在“字段”框中添加字段pid,并对其进行排序,单击【确定】按钮,完成排序记录3控件的配置。
在这里插入图片描述10.配置表输入2控件,双击“表输入2”控件,进入“表输入2”界面,单击【新建】按钮,配置数据库连接,配置完成后单击【确认】按钮。
在这里插入图片描述在这里插入图片描述11.配置排序记录4控件,双击“排序记录 4”控件,进入“排序记录”界面,在“字段”框中添加字段pid,并对其进行排序,单击【确定】按钮,完成“排序记录4”控件的配置。
在这里插入图片描述12.配置记录集连接2控件,双击“记录集连接2”控件,进入“合并排序”界面,在“第一个步骤”处的下拉框中选择“排序记录3”,“第二个步骤”处的下拉框中选择“排序记录4”;在“第一个步骤的连接字段”和“第二个步骤的连接字段”处添加连接字段,这里添加的连接字段是pid;在“连接类型”处的下拉框选择连接类型,这里选择的LEFT OUTER,即左外连接。
在这里插入图片描述13.配置字段选择3控件,双击“字段选择3”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称,这里添加的是记录集连接2流中的字段household_register和Provincial。
在这里插入图片描述14.配置表输出控件
1)双击“表输出”控件,进入“表输出”配置界面,单击【新建】按钮,配置数据库连接,配置完成后单击【确认】按钮。
2) 单击目标表右侧的【浏览】按钮,选择输出的目标表,即临时数据表personnel;勾选“指定数据库字段”的复选框。单击【输入字段映射】按钮,弹出“映射匹配”对话框,依次选中“源字段”选项框的字段和“目标字段”选项框的字段,再单击【Add】按钮,将一对映射字段添加至“映射”选项框中,若“源字段”选项框的字段和“目标字段”选项框的字段相同,则可以单击【猜一猜】按钮,让Kettle自动实现映射。单击映射匹配对话框的【确定】按钮,“表输出”界面最终显示的效果如图所示,单击【确定】按钮,完成“表输出”控件的配置。
在这里插入图片描述15.打开Kettle工具,新建转换,使用Kettle工具,创建一个转换generalization_merge,并添加表输入控件、字段选择控件、排序记录控件、记录集连接控件、文本文件输出控件。
在这里插入图片描述16.配置表输入控件,双击“表输入”控件,进入“表输入”界面,单击【新建】按钮,配置数据库连接,配置完成后单击【确认】按钮。在SQL框中编写SQL语句,用于查询数据表personnel中的数据。
在这里插入图片描述17.配置字段选择控件,双击“字段选择”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称。
在这里插入图片描述18.配置排序记录控件,双击“排序记录”控件,进入“排序记录”界面,并在“字段”框中添加字段id,对其进行排序。

在这里插入图片描述19.配置文本文件输入控件
1)双击“文本文件输入”控件,进入“文本文件输入”界面,单击【浏览】按钮,选择要抽取personnel_data.txt文件;单击【增加】按钮,将要抽取的personnel_data.txt文件添加到generalization_merge转换中。
2)单击“内容”选项卡,在分隔符处清除默认分隔符“;”,单击【Insert TAB】按钮,在分隔符处插入一个制表符;取消勾选“头部”复选框。
3)单击“字段”选项卡,根据personnel_data.txt文件的内容添加对应的字段名称,并指定数据类型。“字段”选项卡的配置。
在这里插入图片描述在这里插入图片描述20.配置字段选择2控件,双击“字段选择2”控件,进入“选择/改名值”界面,在“选择和修改”选项卡处添加字段名称。

在这里插入图片描述21.配置排序记录2控件,双击“排序记录”控件,进入“排序记录”界面,并在“字段”框中添加字段id,对其进行排序。
在这里插入图片描述22.配置记录集连接控件

双击“记录集连接”控件,进入“合并排序”界面,在“第一个步骤”处的下拉框中选择“排序记录”,“第二个步骤”处的下拉框中选择“排序记录2”;在“第一个步骤的连接字段”和“第二个步骤的连接字段”处添加连接字段,这里添加的连接字段是id;在“连接类型”处的下拉框选择连接类型,这里选择的LEFT OUTER,即左外连接。
在这里插入图片描述23.配置字段选择3控件,双击“字段选择3”控件,进入“字段选择”界面,在“选择和修改”选项卡处添加字段名称,并将字段household_register_new改为household_register。
在这里插入图片描述24.配置文本文件输出控件

双击“文本文件输出”控件,进入“文本文件输出”界面,单击“文件名称”右侧的【浏览】按钮,选择输出文件,即文本文件personnel_data_new,单击“内容”选项卡,进入“内容”界面,清除分隔符处的默认分隔符,单击【插入Tab】按钮,插入Tab分隔符。并在编码处的下拉框选择“UTF-8”编码,单击“字段”选项卡,进入“字段”界面,添加要输出的字段。
在这里插入图片描述25.打开Kettle工具,新建作业,使用Kettle工具,创建一个作业generalization,并添加Start控件、转换控件、成功控件。
在这里插入图片描述26.配置转换控件,双击“转换”控件,进入“转换”界面,单击“Transformations”处的【浏览】按钮,选择添加转换generalization。
在这里插入图片描述27.配置转换2控件,双击“转换2”控件,进入“转换”界面,单击“Transformations”处的【浏览】按钮,选择添加转generalization_merge。
在这里插入图片描述28.运行作业generalization,单击作业工作区顶部的start按钮,运行作业generalization,实现将文本文件personnel_data.txt中字段为household_register的数据统一成省份(直辖市),并输出到文本文件personnel_data_new.txt中。
29.查看文本文件personnel_data_new.txt中的数据通过文本编辑器工具,查看文本文件personnel_data_new.txt中的数据。
在这里插入图片描述

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

1.打开Kettle工具,新建转换,使用Kettle工具,创建一个转换monthly_salary,并添加文本文件输入控件、增加常量控件、计算器控件、文本文件输出控件。
在这里插入图片描述2.配置文本文件输入控件
1)双击“文本文件输入”控件,进入“文本文件输入”界面,单击【浏览】按钮,选择要抽取personnel_data_new.txt文件;单击【增加】按钮,将要抽取的personnel_data_new.txt文件添加到转换monthly_salary中。
2)单击“内容”选项卡,在分隔符处清除默认分隔符“;”,单击【Insert TAB】按钮,在分隔符处插入一个制表符;取消勾选“头部”复选框。
在这里插入图片描述在这里插入图片描述3)单击“字段”选项卡,根据personnel_data.txt文件的内容添加对应的字段名称,并指定数据类型。“字段”选项卡的配置。
在这里插入图片描述3.配置增加常量控件

双击“增加常量”控件,进入“增加常量”界面,在字段框中添加一个字段days,并给定一个值22。
在这里插入图片描述4.配置计算器控件,双击“计算器”控件,进入“计算器”界面,在字段框中添加一个字段monthly_salary,用于存储月薪,该字段是由字段days和salary进行相乘所得。
在这里插入图片描述5.配置文本文件输出控件

双击“文本文件输出”控件,进入“文本文件输出”界面,单击“文件名称”右侧的【浏览】按钮,选择输出文件,即文本文件personnel_data_monthly_salary,如图6-52所示;单击“内容”选项卡,进入“内容”界面,清除分隔符处的默认分隔符,单击【插入Tab】按钮,插入Tab分隔符,并在编码处的下拉框选择“UTF-8”编码,单击“字段”选项卡,进入“字段”界面,添加要输出的字段。
在这里插入图片描述6.运行转换monthly_salary

单击转换工作区顶部的start按钮,运行转换monthly_salary,实现将文本文件personnel_data_new.txt中字段为salary的数据进行商务规则计算,即计算每个人的月薪(以22天工作日计算),最终输出到文本文件personnel_data_monthly_salary.txt中。
7.查看文本文件personnel_data_monthly_salary.txt中的数据通过文本编辑器工具,查看文本文件personnel_data_monthly_salary.txt中的数据。
在这里插入图片描述

当涉及到数据清洗的高频面试题时,以下是一些常见的问题和答案: 1. 什么是数据清洗数据清洗是指对原始数据进行处理和转换,以去除错误、不完整、重复或不必要的数据,以确保数据的准确性和一致性。 2. 如何处理缺失值? 处理缺失值的常见方法包括删除包含缺失值的行或列、用均值或中位数填充缺失值、使用插值方法填充缺失值等。 3. 如何处理重复值? 处理重复值的方法包括删除重复值、保留第一个或最后一个重复值、标记重复值等。 4. 如何处理异常值? 处理异常值的方法包括删除异常值、替换为缺失值、使用统计方法进行修正等。 5. 如何处理不一致的数据格式? 处理不一致的数据格式可以使用字符串操作函数(如strip、lower、replace等)进行格式化,或者使用正则表达式进行匹配和替换。 6. 如何处理数据类型转换? 可以使用Python的内置函数(如int、float、str等)进行数据类型转换,或者使用pandas库中的astype函数进行批量转换。 7. 如何处理日期和时间数据? 可以使用Python的datetime模块进行日期和时间数据的解析、格式化和计算,或者使用pandas库中的to_datetime函数进行批量转换。 8. 如何处理文本数据? 处理文本数据的方法包括去除特殊字符、分词、去除停用词、词干提取、词向量化等。 9. 如何处理数据集合的合并和拆分? 可以使用pandas库中的merge函数进行数据集合的合并,使用split函数进行数据集合的拆分。 10. 如何处理数据集中的异常值和离群点? 可以使用统计方法(如均值、标准差)进行异常值和离群点的检测和修正,或者使用可视化工具(如箱线图、散点图)进行可视化分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值