【发布时间】:2017-03-28 07:51:14
【问题描述】:
在 Pandas 数据框列中,我想将字符串中的每个字符转换为整数(就像使用 ord() 所做的那样)并在左侧添加 100。我知道如何使用常规字符串来做到这一点:
st = "JOHNSMITH4817001141979"
a=[ord(x) for x in st]
b=[]
for x in a:
b.append('{:03}'.format(x)) #Add leading zero, ensuring 3 digits
b=['100']+b
b=''.join([ "%s"%x for x in b])
b=int(b)
b
结果:100074079072078083077073084072052056049055048048049049052049057055057
但是,如果我想对像这样的 Pandas 数据框中的列的每个单元格执行此操作怎么办?
import pandas as pd
df = pd.DataFrame({'string':['JOHNSMITH4817001141979','JOHNSMYTHE4817001141979']})
df
string
0 JOHNSMITH4817001141979
1 JOHNSMYTHE4817001141979
我只需要一个单独的列,将结果作为“字符串”中每个单元格的整数。
提前致谢!
【问题讨论】:
标签: python string pandas integer apply