问题设置
import pandas as pd
df = pd.DataFrame(data={'Currency': {0: 111.23, 1: 321.23},
'Int': {0: 23, 1: 3},
'Rate': {0: 0.03030, 1: 0.09840}}
)
生成以下DataFrame
Currency Int Rate
0 111.23 23 0.0303
1 321.23 3 0.0984
我想使用如下所示的dict将非常特定的格式应用于数据框中的每一列:
format_mapping={'Currency': '${:,.2f}', 'Int': '{:,.0f}', 'Rate': '{:.2f}%'}
我知道我可以将applymap用于多列或应用于单个列:
#All columns
df = df.applymap('{:.2f}%'.format)
#Specific columns
df['Rate'] = df['Rate'].apply('{:.2f}%'.format)
题
如何遍历数据框中的每一列并使用字典应用格式,其中dict键是列,值是字符串格式?
最终结果看起来像这样(忽略百分比现在不再乘以100的事实)
Currency Int Rate
0 $111.23 23 0.03%
1 $321.23 3 0.10%
解决方法:
最简单的方法是遍历format_mapping字典,然后在列(由键表示)上应用由值表示的格式.示例 –
for key, value in format_mapping.items():
df[key] = df[key].apply(value.format)
演示 –
In [62]: df = pd.DataFrame(data={'Currency': {0: 111.23, 1: 321.23},
....: 'Int': {0: 23, 1: 3},
....: 'Rate': {0: 0.03030, 1: 0.09840}}
....: )
In [63]:
In [63]: format_mapping={'Currency': '${:,.2f}', 'Int': '{:,.0f}', 'Rate': '{:.2f}%'}
In [64]: for key, value in format_mapping.items():
....: df[key] = df[key].apply(value.format)
....:
In [65]: df
Out[65]:
Currency Int Rate
0 $111.23 23 0.03%
1 $321.23 3 0.10%
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。