【发布时间】:2014-04-12 03:49:33
【问题描述】:
我开始为此扯头发 - 所以我希望有人能提供帮助。我有一个使用 openpyxl 从 Excel 电子表格创建的 pandas DataFrame。生成的 DataFrame 如下所示:
print image_name_data
id image_name
0 1001 1001_mar2014_report
1 1002 1002_mar2014_report
2 1003 1003_mar2014_report
[3 rows x 2 columns]
…具有以下数据类型:
print image_name_data.dtypes
id float64
image_name object
dtype: object
问题在于 id 列中的数字实际上是标识号,我需要将它们视为字符串。我尝试使用以下方法将 id 列转换为字符串:
image_name_data['id'] = image_name_data['id'].astype('str')
这看起来有点难看,但它确实产生了一个类型为“object”而不是“float64”的变量:
print image_name_data.dyptes
id object
image_name object
dtype: object
但是,创建的字符串有一个小数点,如图:
print image_name_data
id image_name
0 1001.0 1001_mar2014_report
1 1002.0 1002_mar2014_report
2 1003.0 1003_mar2014_report
[3 rows x 2 columns]
如何将 pandas DataFrame 中的 float64 列转换为具有给定格式的字符串(在本例中,例如 '%10.0f')?
【问题讨论】:
标签: python string floating-point pandas format