编写高性能数据处理代码 01

⚠️ 注意,这是一篇软件技术文章,非软件开发者/爱好者 😜😜😜 慎入

各位python开发者/爱好者,我是 Pythonista,爱写优雅的python代码!

在AI飞速发展的今天数据科学占据了极高的地位,编写高效的 Python 代码成为一项重要的技能。

作为数据科学家,我们经常处理复杂的工作流程,在 Pandas 和 NumPy 等库之间切换以进行数据整理,使用 SQL 进行查询,以及使用 regex 进行数据清理和特征提取。

以上四种工具都是常用的,因此,了解更多关于它们的信息总是有用的。

在本文中介绍并行I/O分块读取和处理,这肯定能提升您在 Pandas方面的技能。

"Talk is cheap. Show the code",开干!

python 复制代码
# 以1000000行为每块大小,处理 10GB 的 CSV 文件,并即时进行聚合
agg = []
for chunk in pd.read_csv('big.csv', usecols=['user_id','purchase_amt'], chunksize=10**6):
    agg.append(chunk.groupby('user_id')['purchase_amt'].sum())
result = pd.concat(agg).groupby(level=0).sum()

工作原理:

  • usecols 在 I/O 层跳过解析不必要的列,从而减少内存开销。
  • chunksize 将数据分批流式传输,以避免 OOM 异常。

在 Pandas 中,read_csv() 的参数 usecols 和 chunksize 经常配合使用,用于按块(chunk)读取大型 CSV 文件,提高内存效率,并可以实现并行 I/O 或流式处理。这在处理大文件时非常重要,尤其是在无法一次性读入整个文件的情况下。

基本概念解释

✅ usecols

  • 含义:指定只读取某些列(column)。
  • 作用:减少内存占用,加快读取速度。

✅ chunksize

  • 含义:分块读取,每次读取指定行数,返回的是一个可迭代的 TextFileReader 对象。
  • 作用:避免一次性读取大文件造成内存爆炸。

✅ 并行 I/O 的含义(手动实现)

  • 虽然 Pandas 本身不自动并行处理 chunk,但你可以结合 Python 的多线程或多进程来并行处理每个 chunk,从而实现并行 I/O + 计算。

⚙️ 并行处理 Chunk(可选)

可以使用 concurrent.futures 来并行处理每个 chunk:

python 复制代码
from concurrent.futures import ThreadPoolExecutor
import pandas as pd

def process_chunk(chunk):
    chunk['value'] = chunk['value'] ** 2
    return chunk

reader = pd.read_csv('data.csv', usecols=['id', 'value'], chunksize=10000)

with ThreadPoolExecutor(max_workers=4) as executor:
    results = list(executor.map(process_chunk, reader))

# 合并结果
df_all = pd.concat(results)

总结:

参数 作用 场景
usecols 只读取指定列,节省内存 只关心部分字段,避免加载无用数据
chunksize 分块读取大文件,返回 chunk 流 文件太大,无法一次读入
并行处理 提高读取 + 处理的整体效率 多核环境下处理大数据
相关推荐
学IT的周星星15 小时前
Spring Boot Web 开发实战:第二天,从零搭个“会卖萌”的小项目
spring boot·后端·tomcat
郑州光合科技余经理15 小时前
可独立部署的Java同城O2O系统架构:技术落地
java·开发语言·前端·后端·小程序·系统架构·uni-app
json{shen:"jing"}15 小时前
js收官总概述
开发语言·python
双层吉士憨包16 小时前
Airbnb(爱彼迎)爬虫全流程解析:用 Python 抓取房源数据实战指南
python·ai·网络爬虫
小北方城市网16 小时前
RabbitMQ 生产级实战:可靠性投递、高并发优化与问题排查
开发语言·分布式·python·缓存·性能优化·rabbitmq·ruby
曲幽16 小时前
FastAPI部署中间件实战:从CORS到自定义,让你的API更健壮
python·fastapi·web·cors·starlette·middleware·call_next
郝学胜-神的一滴16 小时前
Python中的bisect模块:优雅处理有序序列的艺术
开发语言·数据结构·python·程序人生·算法
Remember_99316 小时前
Spring 事务深度解析:实现方式、隔离级别与传播机制全攻略
java·开发语言·数据库·后端·spring·leetcode·oracle
jackylzh16 小时前
PyTorch 2.x 中 `torch.load` 的 `FutureWarning` 与 `weights_only=False` 参数分析
人工智能·pytorch·python