python发邮件:pandas DataFrame.to_html 改变

系统 2823 0

工作中需要利用邮件每天向领导发送报表和一些统计数据,利用python可以实现每天定时发送非常方便,而且可以在正文中附上pandas dataframe表格,df.to_html就可以实现

  • 首先我们先看下官方文档的解释:
    pandas.DataFrame.to_html

用法非常简单,但是如果我们想把表格制作得更友好一些呢? 毕竟领导的时间很宝贵。
比如我们想让表格里的数字显示千分位分隔符,同时保留两位小数
那就可以通过float_format 或者 formatters来指定显示规则,一开始对于官方文档的解释不是很懂

  • formatters : list or dict of one-parameter functions, optional
    formatter functions to apply to columns’ elements by position or name, default None. The result of each function must be a unicode string. List must be of length equal to the number of columns.

  • float_format : one-parameter function, optional
    formatter function to apply to columns’ elements if they are floats, default None. The result of this function must be a unicode string.

这里的 on-parameter function 长什么样呢?

摸索了一下,这里的format函数可以通过以下两种方式定义:

  • 常规定义法 def
            
              
                def
              
              
                myFormat
              
              
                (
              
              x
              
                )
              
              
                :
              
              
                # 保留两位小数,显示千分位分隔符
              
              
                return
              
              
                format
              
              
                (
              
              x
              
                ,
              
              
                ',.2f'
              
              
                )
              
            
          
  • lambda 定义法
            
              
                lambda
              
               x
              
                :
              
              
                format
              
              
                (
              
              x
              
                ,
              
              
                ',.2f'
              
              
                )
              
            
          

这里的formatters可以指定某些列的格式(包括但不限于数字的格式),float_format则是应用于表格中所有的数字(float)

  • 更复杂的formatt可参考 Style

用法如下

            
              df
              
                .
              
              to_html
              
                (
              
              index
              
                =
              
              
                False
              
              
                ,
              
               formaters
              
                =
              
              
                {
              
              
                'A'
              
              
                :
              
              myFormat
              
                }
              
              
                )
              
              
                # 其中A列为数字
              
              
                # 或者
              
              
df
              
                .
              
              to_html
              
                (
              
              index
              
                =
              
              
                False
              
              
                ,
              
               float_format
              
                =
              
              
                lambda
              
               x
              
                :
              
              
                format
              
              
                (
              
              x
              
                ,
              
              
                ',.2f'
              
              
                )
              
              
                )
              
            
          

更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论