python处理300万数据_高效处理300万熊猫数据帧行

我需要处理一个包含300万行和7列的大型csv文件。

数据帧形状:(3421083,7)

我的计划是删除包含某个值(客户id)的所有行,我将如何继续:#keep track of iterations

track = 0

#import all transactions (orders.csv)

transactions = pd.read_csv('transactions.csv')

#We select all orders that are electronics orders and put them into a df

is_electronics = transactions[transactions.type == "electronics"]

#Create arrays that will store users to destroy in transactions.csv

users_to_remove = []

#iterate to add appropriate values:

# we add all users that ordered electronics to a list

for user in is_electronics.user_id:

users_to_remove.append(user)

#We delete from orders.csv

for user in users_to_remove:

transactions = transactions[transactions.user_id != user]

track += 1

if track == 100000:

print(track)

track = 0

transactions.to_csv('not_electronics.csv', index = False)

这项手术花了很长时间我运行了一个小时,它仍然没有完成。在

我有一个四核桌面i5,3.2GHz和8gb内存。但是在活动监视器中,计算机只使用5gb的ram和40%的cpu。在

有什么方法可以加快这个过程的计算速度吗?是通过更改代码还是使用其他库?在

我也有一个gpu(gtx 970)我可以用它来处理这个吗?在

谢谢。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值