pandas替换一列中的汉字为数字

Posted sxinfo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pandas替换一列中的汉字为数字相关的知识,希望对你有一定的参考价值。

表格的一列“总金额”应该全部为数字,但其中少数项出现汉字,应该将汉字替换为数字,才能进行后面的计算。

先定义一个函数:

def is_number(s):
    try:
        float(s)
        return True
    except ValueError:
        pass
 
    try:
        import unicodedata
        unicodedata.numeric(s)
        return True
    except (TypeError, ValueError):
        pass
 
    return False
 

  再引用这个函数:

df[‘成交金额‘] = df[‘成交金额‘].map(lambda x: np.where(is_number(x), x, 1000)) #先替换
df[‘成交金额‘] = df[‘成交金额‘].apply(pd.to_numeric) #类型指定为数值型
df[‘成交金额‘] = round(df[‘成交金额‘]/100000000,2) #再计算

  

以上是关于pandas替换一列中的汉字为数字的主要内容,如果未能解决你的问题,请参考以下文章

Python Pandas根据多个其他列中的条件替换一列中的值[重复]

使用字典替换 Pandas 列中字符串中的字符串

pandas:用列中的最后一个非 NaN 值替换 NaN [重复]

查找列中的唯一值并将唯一值替换为数字

大量数据,尝试替换一列中的分隔符但不是所有分隔符

Excel怎么删除一列中的特定字