回炉整理《数据分析实战45讲》之基础篇 -- 11.数据清洗(二)

2023-11-04 10:20

本文主要是介绍回炉整理《数据分析实战45讲》之基础篇 -- 11.数据清洗(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上篇补了 “完全合一” 中的“完整性”这个部分掌柜觉得需要了解的知识点,接下来继续看全面性。还是回到服装店会员数据表那里,掌柜觉得这里的“全面性”指的是数据要规范:即大小写要统一、有单位的要统一单位、数据长度也要一致(小数点后面是几位都要统一)、数据名称保持一致等。

  • 那么再看这里的表格可以发现出现了单位不统一以及之前对均值填充的时候小数点位数变多的情况,只需要统一单位和小数点位数即可。这里把年龄的小数点位数都统一为之前的一位、单位都统一为千克(kgs):
    在这里插入图片描述
    在这里插入图片描述
  • 上面的没有补充的,接着来到 “合法性”,简单来讲就是数据要合乎常理,不会出现异常的情况,比如年龄是负数?性别未知?数据类型出现非ASCII字符等。
    (小小了解一下:所谓的ASCII,通俗来讲就是用一套统一规定的用来表示现代英语字符 同计算机中二进制数之间关系的编码规则。而这套规则又是当时美国的组织提出来的,所以又叫做 美国信息互换标准码(American Standard Code for Information Interchange)。(这里就不再多拓展了,因为这也是一个一挖就很深的点😂,有兴趣的朋友可以私下多面向谷歌了解

再回到这里,这个原始会员信息表出现了非ASCII字符(以语感来说是法语),所以这里进行删除或者替换操作:
在这里插入图片描述
在这里插入图片描述
这里用的是正则匹配ASCII字符,然后再进行删除,可以发现第0行和第7行的非ASCII字符被删除了。

如果不想删除非ASCII字符改变原样本,就想直接替换呢

补充第三点👉:pandas中如何替换非ASCII字符? 可以使用下面这个方法:
在这里插入图片描述
先创建替换的对应字典,然后使用pandas的字符串替换方法即可!

  • 补充第四点👉:如何处理异常值?* 有三种解决办法:
    1. 删除异常值
    2. 把它当作缺失值,用缺失值的方法来处理
    3. 不处理

PS:同样,异常值的处理还是要考虑实际情况,有时候不处理可以发现数据集的其他隐藏信息,比如医学检测的时候。

  • 最后来看唯一性,即数据要唯一,不存在重复、一对多的情况。所以这里存在两个问题:
  1. 一个是Name列包含两个参数First Name 和Last Name,一般不这样操作。所以需要进行一列变多列的拆分:
    在这里插入图片描述
    但是发现没,拆分的新数据列跑到最后去了,所以需要再处理一下:
    在这里插入图片描述

  2. 最后处理重复数据,用duplicated()查询重复数据,再用drop_duplicates()方法删除重复数据:
    PPS: 关于数据去重掌柜这里就不补充了,因为之前的博文写过一次,还对比了三种工具去重的方法,可以移步👉数据去重的各种方法汇总)
    在这里插入图片描述
    在这里插入图片描述
    最后再把处理干净的表存储到Excel中:
    在这里插入图片描述
    总算把第十一章要补的知识点搞定了,才发现一章就可以整理好多出来😂,最后脑图和代码掌柜都一并打包到GitHub去了,请自取👇:
    GitHub

然后十一章还留了一个练习题
在这里插入图片描述
想要练习和参考答案的可以一并去GitHub上面查看,喜欢可以关注,谢谢!😄

参考资料:
Pandas替换非ASCII字符

这篇关于回炉整理《数据分析实战45讲》之基础篇 -- 11.数据清洗(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/345110

相关文章

Android Mainline基础简介

《AndroidMainline基础简介》AndroidMainline是通过模块化更新Android核心组件的框架,可能提高安全性,本文给大家介绍AndroidMainline基础简介,感兴趣的朋... 目录关键要点什么是 android Mainline?Android Mainline 的工作原理关键

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键