RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1567297
Accepted
lmnsv03
lmnsv03
Asked:2024-02-21 05:11:55 +0000 UTC2024-02-21 05:11:55 +0000 UTC 2024-02-21 05:11:55 +0000 UTC

从 pandas 库调用 .mean() 方法时出错

  • 772
import pandas as pd
dict = {'Company': ['COMP1', 'COMP1', 'COMP2', 'COMP2', 'COMP3', 'COMP3'],
        'Months': ['MAR', 'APR', 'MAY', 'JUN', 'JUL', 'AUG'],
        'Salary': [2000, 1500, 3000, 5000, 2500, 3500]}
df = pd.DataFrame(dict)
print(df)
df.groupby('Company').mean()

我正在使用3.12版本,我认为该版本有错误,然后我切换到3.10,但问题仍然存在。请各位程序员帮忙!!!

File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\generic.py", line 12370, in _stat_function
    return self._reduce(   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\series.py", line 6437, in _reduce
    return op(delegate, skipna=skipna, **kwds)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\nanops.py", line 147, in f
    result = alt(values, axis=axis, skipna=skipna, **kwds)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\nanops.py", line 404, in new_func
    result = func(values, axis=axis, skipna=skipna, mask=mask, **kwargs)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\nanops.py", line 720, in nanmean
    the_sum = _ensure_numeric(the_sum)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\nanops.py", line 1701, in _ensure_numeric
    raise TypeError(f"Could not convert string '{x}' to numeric") TypeError: Could not convert string 'MARAPR' to numeric

The above exception was the direct cause of the following exception:

Traceback (most recent call last):   File "D:\pyprojects\pythonProject1\pandas&numpy.py", line 245, in <module>
    df.groupby('Company').mean()   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\groupby\groupby.py", line 2452, in mean
    result = self._cython_agg_general(   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\groupby\groupby.py", line 1998, in _cython_agg_general
    new_mgr = data.grouped_reduce(array_func)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\internals\managers.py", line 1470, in grouped_reduce
    applied = sb.apply(func)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\internals\blocks.py", line 393, in apply
    result = func(self.values, **kwargs)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\groupby\groupby.py", line 1995, in array_func
    result = self._agg_py_fallback(how, values, ndim=data.ndim, alt=alt)   File "C:\Users\respu\AppData\Local\Programs\Python\Python310\lib\site-packages\pandas\core\groupby\groupby.py", line 1946, in _agg_py_fallback
    raise type(err)(msg) from err TypeError: agg function failed [how->mean,dtype->object]
python
  • 1 1 个回答
  • 28 Views

1 个回答

  • Voted
  1. Best Answer
    MarianD
    2024-02-21T07:10:39Z2024-02-21T07:10:39Z

    错误在于,分组后仍然有一列不Months包含数字,而是包含字符串- 如何计算它们的平均值?

    解决方案 - 有两种可能性:

    1. Salary限制为这样的列:

      df.groupby('Company')['Salary'].mean()
      

      或缩写为:

      df.groupby('Company').Salary.mean()
      

      这些命令输出该系列:

      Company
      COMP1    1750.0
      COMP2    4000.0
      COMP3    3000.0
      Name: Salary, dtype: float64
      

      当您想要输出datatime时,请使用方括号对:

      df.groupby('Company')[['Salary']].mean()
      
               Salary
      Company        
      COMP1    1750.0
      COMP2    4000.0
      COMP3    3000.0
      

    1. 通过使用参数限制所有数字列(在您的情况下 - 只有一个这样的列 - 产生相同的结果)numeric_only=True:

      df.groupby('Company').mean(numeric_only=True)
      

      正如我所说,您将获得相同的数据框

               Salary
      Company        
      COMP1    1750.0
      COMP2    4000.0
      COMP3    3000.0
      
    • 2

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5