百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python 数据转换实用技巧:3 分钟搞定杂乱数据,新手也能学会

off999 2025-07-21 17:03 66 浏览 0 评论


你是不是也遇到过这种情况:好不容易收集到数据,却因为格式乱七八糟没法分析 —— 日期格式五花八门,金额里混着各种符号,想算个平均值都难。其实,用对 Python 数据转换技巧,这些问题都能轻松解决。今天就分享几个超实用的方法,新手也能直接套用。

一、数据类型转换:别让类型错误拖后腿

拿到数据先检查类型,这是最基础也最关键的一步。很多分析出错,都是因为类型不对。

3 种最常用的转换方法

import pandas as pd

# 原始数据

data = {

'订单日期': ['2023-10-05', '2023/10/06', '2023年10月07日'],

'金额': ['399', '129.9', '599'],

'用户ID': ['1001', '1002', '1003'],

'产品类别': ['口红', '粉底', '口红']

}

df = pd.DataFrame(data)

# 1. 字符串转日期

df['订单日期'] = pd.to_datetime(df['订单日期'], errors='coerce')

# 2. 文本金额转数字

df['金额'] = pd.to_numeric(df['金额'], errors='coerce')

# 3. 字符串用户ID转整数

df['用户ID'] = pd.to_numeric(df['用户ID'], downcast='integer')

# 4. 产品类别转分类类型(省内存)

df['产品类别'] = df['产品类别'].astype('category')

转换时的 3 个避坑点

  • 转换失败不报错:加上errors='coerce',失败的会变成NaN,程序继续运行
  • 日期格式乱不怕:pd.to_datetime能自动识别大部分格式,省心
  • 大整数别用 int64:downcast='integer'会自动选合适类型,节省内存

检查转换效果:

# 看每列有多少转换失败的

print(df.isnull().sum())

二、格式转换:让数据 “说同一种话”

不同来源的数据格式往往不一样,必须统一才能分析。

日期格式统一

def 统一日期格式(日期列, 目标格式='%Y-%m-%d'):

# 先转成datetime类型

日期时间列 = pd.to_datetime(日期列, errors='coerce')

# 再转成目标字符串格式

统一格式列 = 日期时间列.dt.strftime(目标格式)

# 转换失败的保留原始值

转换失败 = 日期时间列.isna()

统一格式列[转换失败] = 日期列[转换失败].astype(str)

return 统一格式列

# 用法

df['订单日期_统一'] = 统一日期格式(df['订单日期'], '%Y年%m月%d日')

金额里的符号怎么处理?

# 处理带货币符号的金额,如"yen399" "$129.9"

df['金额_清洗'] = df['金额字符串'].astype(str).str.extract(r'(\d+\.?\d*)').astype(float)

# 处理欧洲格式数字,如"1.234,56"(逗号是小数点)

def 欧洲数字转正常(数字列):

清洗列 = 数字列.str.replace('.', '', regex=False)

清洗列 = 清洗列.str.replace(',', '.', regex=False)

return 清洗列.astype(float)

三、结构转换:长表宽表按需转

数据结构不对,分析起来很费劲,长表宽表转换是常用技巧。

长表转宽表(适合汇总)

# 长表数据

长表 = pd.DataFrame({

'用户ID': [1001, 1001, 1002, 1002],

'月份': ['1月', '2月', '1月', '2月'],

'消费金额': [399, 599, 299, 499]

})

# 转宽表:一行一个用户,一列一个月份

宽表 = 长表.pivot(

index='用户ID',

columns='月份',

values='消费金额'

).reset_index()

宽表转长表(适合趋势分析)

# 把宽表转回去

长表2 = pd.melt(

宽表,

id_vars=['用户ID'], # 保持不变的列

value_vars=['1月', '2月'], # 要转换的列

var_name='月份', # 新列名(原列名)

value_name='消费金额' # 新列名(原数值)

)

四、嵌套数据转换:JSON 信息轻松拆

很多数据存在 JSON 格式的字段里,比如用户信息是{"姓名":"张三","年龄":30},这样拆出来:

import json

def 拆JSON列(数据框, 列名):

def 解析JSON(x):

try:

return json.loads(x) if pd.notna(x) else {}

except:

return {} # 解析失败返回空字典

解析结果 = 数据框[列名].apply(解析JSON)

拆出来的列 = pd.json_normalize(解析结果)

拆出来的列.columns = [f'{列名}_{子列}' for 子列 in 拆出来的列.columns]

return pd.concat([数据框.drop(列名, axis=1), 拆出来的列], axis=1)

# 用法

# df = 拆JSON列(df, 'user_info')

# 会多出user_info_姓名、user_info_年龄等列

五、实战案例:电商订单数据转换全流程

处理有这些问题的订单数据:

  • 订单日期格式混乱
  • 金额带货币符号
  • 用户信息是 JSON 格式
  • 评论有乱码
def 处理订单数据(原始数据):

df = 原始数据.copy()

# 1. 类型转换

df['订单日期'] = pd.to_datetime(df['订单日期'], errors='coerce')

df['金额'] = df['金额'].astype(str).str.extract(r'(\d+\.?\d*)').astype(float)

# 2. 格式统一

df['订单日期_标准'] = 统一日期格式(df['订单日期'])

df['订单月份'] = df['订单日期'].dt.month # 提取月份

# 3. 拆JSON列

df = 拆JSON列(df, '用户信息')

# 4. 处理评论乱码

df['评论_清洗'] = df['评论'].str.encode('latin-1').str.decode('utf-8', errors='ignore')

return df

3 个实用小技巧

  1. 转换前备份:df_copy = df.copy(),转错了还能重来
  1. 大文件分块处理:pd.read_csv(chunksize=10000),省内存
  1. 检查内存占用:df.memory_usage(deep=True).sum()/1024/1024,太大就优化类型

掌握这些数据转换技巧,再乱的数据也能变得整整齐齐,分析起来事半功倍。赶紧试试,有问题评论区留言。觉得有用,点赞收藏吧!

相关推荐

磁盘分区工具软件(硬盘分区工具软件)

如果说最安全的那就用电脑自带的吧,右键我的电脑,找到管理,然后进去磁盘管理,然后找到目前的一个磁盘,右键压缩卷,输入压缩空间就是你想要的一个盘的大小(1G=1024MB),然后压缩,然后找到你压缩出来...

ftp手机客户端(ftp手机客户端存文件)

要想实现FTP文件传输,必须在相连的两端都装有支持FTP协议的软件,装在您的电脑上的叫FTP客户端软件,装在另一端服务器上的叫做FTP服务器端软件。  客户端FTP软件使用方法很简单,启动后首先要与...

原版xp系统镜像(原版xp系统镜像怎么设置)

msdnitellyou又可以上了,那里有。  制作需要的软件  在开始进行制作之前,我们首先需要下载几个软件,启动光盘制作工具:EasyBoot,UltraISO以及用来对制作好的ISO镜像进行测...

office2007密钥 office2016(office2007ultimate密钥)

word2016激活密钥有两种类型:永久激活码和KMS期限激活密钥。其中,永久激活密钥可以使用批量授权版永久激活密钥进行激活,如所示;而KMS期限激活密钥需要使用KMS客户端密钥进行激活,如所示。另外...

windows10系统启动盘制作(windows10启动盘制作教程)

Windows10系统更改启动磁盘的方法如下1、按快捷键Win+R,调出命令窗口2、输入msconfig,点【确定】3、在系统配置中,选择【引导】菜单4、选择要默认启动的磁盘,点【设置为默认值】,...

方正电脑怎么重装系统

购买一张系统盘,然后启动电脑,将购买的系统盘插入电脑光驱中,等待光驱读取系统盘后,点击安装系统,即可自动安装,等待安装完毕,电脑会自动重启,重新启动后,电脑的系统就安装完毕,可以使用了一、准备需要的软...

qq邮箱怎么写才正确
qq邮箱怎么写才正确

步骤/方式1一般默认的QQ邮箱格式是:QQ号码@qq.com,即QQ账号+@qq.com后缀步骤/方式2若要发送邮件,也要在对方的qq帐号末尾加上@qq.com1.每个人在注册QQ时都会有关联的一个邮箱,它的格式就是“QQ号码@qq.com...

2025-12-21 18:51 off999

电脑怎么看配置信息
电脑怎么看配置信息

要查看Windows电脑的配置信息,可以通过按下Win键+R,然后在弹出的运行对话框中输入“dxdiag”并按回车键打开DirectX诊断工具,可以查看有关处理器、内存、显卡等硬件信息。另外,还可以右键点击“此电脑”,选择“属性”来查看...

2025-12-21 18:03 off999

mpeg是什么格式(mpeg是什么格式和mp4的区别)

是视频格式,是电脑视频文件的一种,相对其它视频文件格式而言,mpeg格式占的存储空间相对比较小,那么像素也就相对比较低,图像也没有其它格式那么高清,不过一般情况下已经满足正常的使用。好多视频文件都是采...

电脑参数配置怎么选(电脑参数配置怎么选择)

1、CPU,这个主要取决于频率和二级缓存,三级缓存,核心数量。频率越高、二级缓存越大,三级缓存越大,核心越多,运行速度越快。速度越快的CPU只有三级缓存影响响应速度。2、内存,内存的存取速度取决于接口...

windows7字体(Windows7字体库在哪)

win7系统默认中文字体是微软雅黑字体1、首先我们先打开个性化2、然后我们打开“窗口颜色”3、然后我们点击“项目”里的桌面,选择“已选定的项目”4、下面就可以改字体,还有字体的颜色、大小5、然后点击“...

windows7x86是32位吗(windows7 x86)

X86不是代表操作系统,是代表的CPU的类型,如果你知道CPU的发展史就知道,个人用计算机的CPU很早的版本是从286、386、486、586、奔腾等等类型发展起来的,所以X86的代表PC的CPU的类...

固态硬盘删除后又自动恢复了

进入BIOS查看,第一启动项是不是UEFI引导,改掉它可以下载个pe,下载安装在本地磁盘里,重启进入pe工具,先给固态格式化分区,在ghost机械盘上的系统,还原到固态上。遇到这种情况一定不要在此...

win10版本回退(win10回退到以前版本)

如果你想在Windows10系统中回退到上一个版本,可以按照以下步骤进行操作:1.打开设置:点击Windows开始按钮,然后点击屏幕左侧的“设置”图标,或者使用键盘快捷键Win+I打开设置。2...

营业厅一个路由器多少钱(上门更换路由器收费吗)

移动免费装宽带活动全国都在搞,不过免费是有“门槛”的。以我所在的地区为例,只有月费在78元及以上的大流量套餐用户,才可以享受免费安装移动的宽带。月费越高,宽带的速率也越高,148元档可以安装200M的...

取消回复欢迎 发表评论: