我开始因这个问题而感到非常苦恼 - 所以我希望有人能帮助我。我有一个pandas DataFrame,它是使用openpyxl从Excel电子表格创建的。生成的DataFrame如下所示:
I'm starting to tear my hair out with this - so I hope someone can help. I have a pandas DataFrame that was created from an Excel spreadsheet using openpyxl. The resulting DataFrame looks like:
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列转换为字符串:
问题在于 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')的字符串?