Merge Dataframe报错You are trying to merge on object and float64 columns

问题描述

将900个csv读取成DataFrame进行Merge操作:

import pandas as pd

df_pri=pd.read_csv('C:/Users/38266/Desktop/t/csvFile/0.csv')
for i in range(1,900):
    df=pd.read_csv('C:/Users/38266/Desktop/t/csvFile/'+str(i)+'.csv')
    df_pri = pd.merge(df_pri, df, how='outer')
    print(str(i))
df_pri.to_csv('result.csv',header=True,index=False)

出现以下错误:

在这里插入图片描述

问题分析

根据错误提示,应该其中有表格的某个或多个字段类型和其他表格的不一致,无法进行合并。所以,我们解决的思路是将所有值转换成一种类型。转换成什么类型呢?因为没有数值计算的需求,所以我们统一转换成str类型。

解决办法

在读取csv时,使用read_csvdtype参数,指定类型。

修改后代码:

import pandas as pd

df_pri=pd.read_csv('C:/Users/38266/Desktop/t/csvFile/0.csv',dtype='str')
for i in range(1,900):
    df=pd.read_csv('C:/Users/38266/Desktop/t/csvFile/'+str(i)+'.csv',dtype='str')
    df_pri = pd.merge(df_pri, df, how='outer')
    print(str(i))
df_pri.to_csv('result.csv',header=True,index=False)
print('OK')

其他方法

[1]Pandas合并2个Dataframe报错:You are trying to merge on object and int64 columns.

[2]【Python数据清洗】使用merge合并2个Dataframe报错:You are trying to merge on object and int64

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值