巨型野兽先辈 2021-12-19 19:57 采纳率: 100%
浏览 3309
已结题

关于python的FutureWarning如何解决

问题遇到的现象和发生背景

做题过程中发现的问题

问题相关代码,请勿粘贴截图

对于一个表格表示总值,并输出最后一行

def task2():
    import warnings
    df=pd.read_csv(r'C:\Users\win10\Desktop\nftd\soi_dropnan.txt')
    df.loc['列汇总']=df.sum()
    print(df.tail(1))
运行结果及报错内容
task2()

Warning (from warnings module):
  File "C:\Users\win10\Desktop\nftd\1.py", line 17
    df.loc['列汇总']=df.sum()
FutureWarning: Dropping of nuisance columns in DataFrame reductions (with 'numeric_only=None') is deprecated; in a future version this will raise TypeError.  Select only valid columns before calling the reduction.
    Date     soi
列汇总  NaN -102.54

我的解答思路和尝试过的方法

在网络上寻找了很久,试了一些的屏蔽报错的方法,不过没有结果

我想要达到的结果

看不见报错即可

  • 写回答

1条回答 默认 最新

  • CSDN专家-HGJ 2021-12-20 00:04
    关注

    应该是读取的数据框中有日期列,在调用sum函数由于默认参数为numeric_only=None,在新版中会舍弃,所以报警告信息。根据你的代码,建议在sum函数中添加参数numeric_only=True,这样就不会有警告信息了,测试版本pandas1.3.2.,另外,也可以用 df.loc['列汇总']=df['value'].sum()。示例代码:

    import pandas as pd
    df = pd.DataFrame(
        {
            "duration":[pd.to_datetime('2012-01-05')+pd.Timedelta(i,unit='days') for i in range(1,6)],
            "value":[1,0,1,2,1]
        }
    )
    print(df)
    df.loc['列汇总'] = df['value'].sum()
    print(df)
    df.loc['列汇总']=df.sum(numeric_only=True)
    print(df.tail(1))
    
    
    

    如果解答对你有帮助,请点击采纳按钮给予支持。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 12月31日
  • 已采纳回答 12月23日
  • 创建了问题 12月19日

悬赏问题

  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥15 键盘指令混乱情况下的启动盘系统重装