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

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

off999 2025-07-21 17:03 13 浏览 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,太大就优化类型

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

相关推荐

PYTHON-简易计算器的元素介绍

[烟花]了解模板代码的组成importPySimpleGUIassg#1)导入库layout=[[],[],[]]#2)定义布局,确定行数window=sg.Window(&#...

如何使用Python编写一个简单的计算器程序

Python是一种简单易学的编程语言,非常适合初学者入门。本文将教您如何使用Python编写一个简单易用的计算器程序,帮助您快速进行基本的数学运算。无需任何高深的数学知识,只需跟随本文的步骤,即可轻松...

用Python打造一个简洁美观的桌面计算器

最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...

用Python制作一个带图形界面的计算器

大家好,今天我要带大家使用Python制作一个具有图形界面的计算器应用程序。这个项目不仅可以帮助你巩固Python编程基础,还可以让你初步体验图形化编程的乐趣。我们将使用Python的tkinter库...

用python怎么做最简单的桌面计算器

有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...

说好的《Think Python 2e》更新呢!

编程派微信号:codingpy本周三脱更了,不过发现好多朋友在那天去访问《ThinkPython2e》的在线版,感觉有点对不住呢(实在是没抽出时间来更新)。不过还好本周六的更新可以实现,要不就放一...

构建AI系统(三):使用Python设置您的第一个MCP服务器

是时候动手实践了!在这一部分中,我们将设置开发环境并创建我们的第一个MCP服务器。如果您从未编写过代码,也不用担心-我们将一步一步来。我们要构建什么还记得第1部分中Maria的咖啡馆吗?我们正在创...

函数还是类?90%程序员都踩过的Python认知误区

那个深夜,你在调试代码,一行行检查变量类型。突然,一个TypeError错误蹦出来,你盯着那句"strobjectisnotcallable",咖啡杯在桌上留下了一圈深色...

《Think Python 2e》中译版更新啦!

【回复“python”,送你十本电子书】又到了周三,一周快过去一半了。小编按计划更新《ThinkPython2e》最新版中译。今天更新的是第五章:条件和递归。具体内容请点击阅读原文查看。其他章节的...

Python mysql批量更新数据(兼容动态数据库字段、表名)

一、应用场景上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。二、解决思路为了解决批量删除和批量更新的问题,提出如下思路:所有更新语...

Python Pandas 库:解锁 combine、update 和compare函数的强大功能

在Python的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索Pandas库中四个功能独特的函数:combine、combine_fi...

记录Python3.7.4更新到Python.3.7.8

Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...

Python千叶网原图爬虫:界面化升级实践

该工具以Python爬虫技术为核心,实现千叶网原图的精准抓取,突破缩略图限制,直达高清资源。新增图形化界面(GUI)后,操作门槛大幅降低:-界面集成URL输入、存储路径选择、线程设置等核心功能,...

__future__模块:Python语言版本演进的桥梁

摘要Python作为一门持续演进的编程语言,在版本迭代过程中不可避免地引入了破坏性变更。__future__模块作为Python兼容性管理的核心机制,为开发者提供了在旧版本中体验新特性的能力。本文深入...

Python 集合隐藏技能:add 与 update 的致命区别,90% 开发者都踩过坑

add函数的使用场景及错误注意添加单一元素:正确示例:pythons={1,2}s.add(3)print(s)#{1,2,3}错误场景:试图添加可变对象(如列表)会报错(Pytho...

取消回复欢迎 发表评论: