进行数据处理的6个 Python 代码块分享

作者:Python学习与数据挖掘 时间:2022-10-21 12:56:18 

前言:

大家好,今天和大家分享自己总结的6个常用的 Python 数据处理代码,对于经常处理数据的coder最好熟练掌握。

1、选取有空值的行

在观察数据结构时,该方法可以快速定位存在缺失值的行。

df = pd.DataFrame({'A': [0, 1, 2],
                   'B': [0, 1, None],
                   'C': [0, None, 2]})
df[df.isnull().T.any()]

输出:

  A   B   C           A   B   C
0 0 0.0 0.0         1 1 1.0 NaN
1 1 1.0 NaN   -->   2 2 NaN 2.0
2 2 NaN 2.0

2、快速替换列值

实际数据处理经常会根据一些限定条件来替换列中的值。

df = pd.DataFrame({'name':['Python', 'Java', 'C']})

# 第一种方式
df['name'].replace('Java', 'JavaScript', inplace=True)
# 第二种方式
df.loc[df['name'].str.contains('Java'), 'name'] = 'JavaScript'

输出:

     name                   name
0  Python          0      Python
1    Java    --->  1  JavaScript
2       C          2           C

3、对列进行分区

很多情况下,对于数值类型的数据,我们需要分区来计算每个区间数据出现的频率。这时用 pd.cut 就能很好的解决这一问题。

import random

age = random.sample(range(90), 20)
cut_res = pd.cut(age, bins=[0, 18, 35, 60, 90])
# cut_res type:<class 'pandas.core.arrays.categorical.Categorical'>
cut_res.value_counts()

输出:

(0, 18]     6
(18, 35]    1
(35, 60]    6
(60, 90]    7

4、将一列分为多列

在文本数据清洗时,一些列中存在分隔符(&lsquo;&rsquo;, &lsquo;,&rsquo;, &lsquo;:&rsquo;)分隔的值,我们只需将该列根据分隔符进行 split 即可。

import pandas as pd

df = pd.DataFrame({'address': ['四川省 成都市',
                               '湖北省 武汉市',
                               '浙江省 杭州市']})
res = df['address'].str.split(' ', expand=True)  
res.columns = ['province', 'city']

输出:

  province city
0 四川省    成都市
1 湖北省    武汉市
2 浙江省    杭州市

expand参数选择是否扩展为 DataFrame,False 则返回 Series

5、中文筛选

同样在清洗过程中,往往会出现一些不需要的中文字段,这时直接用 str.contains 筛选即可。

df = pd.DataFrame({'mobile_phone':
                   ['15928765644',
                    '15567332235',
                    '暂无']})
df[~df['mobile_phone'].str.contains('[\u4e00-\u9fa5]')]

输出:

  mobile_phone         mobile_phone
0 15928765644        0 15928765644
1 15567332235   -->  1 15567332235
2 暂无

6、更改列的位置

有时我们需要调整列的位置,当数据列较少时,可以用下面的方式

df = pd.DataFrame({'name': ['A', 'B', 'C'],
                   'age': [10, 20, 30],
                   'gender': [0, 1, 0]})
df = df[['name', 'gender', 'age']]

输出:

 name age gender    name gender age
0   A  10 0        0   A 0       10
1   B  20 1   -->  1   B 1       20
2   C  30 0        2   C 0       30

如果列较多,那么,一个个列举出来会比较繁琐,推荐下面插入的方式。

col = df['gender']
df.drop('gender', axis=1, inplace=True)
df.insert(1, 'gender', col)

来源:https://blog.csdn.net/weixin_38037405/article/details/123964579

标签:Python,数据,处理,代码块
0
投稿

猜你喜欢

  • Go语言实现彩色输出示例详解

    2023-09-14 01:19:45
  • ASP实现网站智能分词搜索

    2007-10-18 13:50:00
  • asp base64 utf-8为了兼容asp.net的base64

    2011-03-10 10:47:00
  • 很有创意的鼠标指针风筝

    2007-09-22 09:24:00
  • python学习必备知识汇总

    2022-01-05 10:26:23
  • 朴素贝叶斯算法的python实现方法

    2023-03-01 07:05:53
  • layui 富文本图片上传接口与普通按钮 文件上传接口的例子

    2024-05-22 10:36:28
  • firebug1.7调试实用技巧指南

    2011-06-27 20:17:22
  • vue中的封装常用工具类

    2024-05-09 15:19:38
  • python修改txt文件中的某一项方法

    2021-02-08 14:26:40
  • Django rest framework如何自定义用户表

    2022-03-12 01:15:02
  • python实现简单的飞机大战

    2023-07-08 09:16:10
  • python用分数表示矩阵的方法实例

    2023-12-22 21:58:11
  • asp下实现代码的“运行代码”“复制代码”“保存代码”功能源码

    2011-04-14 10:39:00
  • 用Python解数独的方法示例

    2021-01-31 18:38:44
  • oracle用什么SQL语句判断表存不存在

    2010-07-23 13:23:00
  • PHP中array_slice函数用法实例详解

    2023-06-20 20:18:04
  • JS关于 replace 取值、替换第几个匹配项问题小结

    2024-04-25 13:11:05
  • Access的特点及其概念问答

    2009-09-10 19:00:00
  • ASP.NET MVC中两个配置文件的作用详解

    2024-05-13 09:17:08
  • asp之家 网络编程 m.aspxhome.com