鱼C论坛

 找回密码
 立即注册
查看: 2535|回复: 9

请问这段代码哪里出错了

[复制链接]
发表于 2020-4-2 21:13:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
请问这段代码哪里出错了,我想筛选出”会计科目“这一列数值等于”投资收益“,”经营收入“,”其他收入“等这些数据应该怎么写
  1. import pandas as pd
  2. df = pd.read_excel(r'C:\Users\baoch\Desktop\test\财务收支公开明细表.XLSX',header =8)
  3. #nrows = df.shape[0]
  4. #print(nrows)
  5. df2 = df[df['会计科目'].str.contains('其他收入')]
  6. print(df2)
复制代码


错误信息如下:
  1. C:\Users\baoch\AppData\Local\Programs\Python\Python38\python.exe C:/Users/baoch/Desktop/test/提取收入明细.py
  2. Traceback (most recent call last):
  3.   File "C:/Users/baoch/Desktop/test/提取收入明细.py", line 5, in <module>
  4.     df2 = df[df['会计科目'].str.contains('其他收入')]
  5.   File "C:\Users\baoch\AppData\Local\Programs\Python\Python38\lib\site-packages\pandas\core\frame.py", line 2790, in __getitem__
  6.     if com.is_bool_indexer(key):
  7.   File "C:\Users\baoch\AppData\Local\Programs\Python\Python38\lib\site-packages\pandas\core\common.py", line 136, in is_bool_indexer
  8.     raise ValueError(na_msg)
  9. ValueError: Cannot mask with non-boolean array containing NA / NaN values

  10. Process finished with exit code 1
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-4-2 21:38:54 | 显示全部楼层
哪位大神指点下
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 10:32:32 | 显示全部楼层
import pandas as pd
df = pd.read_excel(r'C:\Users\baoch\Desktop\test\财务收支公开明细表.XLSX',header =8)
#nrows = df.shape[0]
#print(nrows)
df2 = df[df['会计科目'].str.contains('其他收入')]
print(df2)
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 10:33:08 | 显示全部楼层
不要用#,删掉
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 13:11:11 | 显示全部楼层

删掉就能正确运行吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 14:46:46 | 显示全部楼层
zltzlt 发表于 2020-4-3 13:11
删掉就能正确运行吗?

是的,我在网上看过
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-3 21:32:32 | 显示全部楼层
Pythonbn 发表于 2020-4-3 14:46
是的,我在网上看过

兄嘚,你的答案貌似有点离谱啊,我加“#”,是因为那两句不需要运行,我就是写出来以防万一要用到。不过谢谢你的回答,我已经测试出来了。后面加上恒等于1就行了,df2 = df[df['会计科目'].str.contains('其他收入')==1]
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-3 21:43:25 | 显示全部楼层
要我帮忙吗?
你那种方法我是没用过,我一般这么提取,某一列值判断是否等于某一值然后提取
df.loc[df["会计科目"]].isin([”投资收益“,”经营收入“,”其他收入“])
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-11 20:11:55 | 显示全部楼层
Chysial 发表于 2020-4-3 21:43
要我帮忙吗?
你那种方法我是没用过,我一般这么提取,某一列值判断是否等于某一值然后提取
df.loc[df[" ...

你这个方法是同时满足这三个条件还是满足其中一个就可以提取啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-15 11:06:23 | 显示全部楼层
脚印拾零 发表于 2020-4-11 20:11
你这个方法是同时满足这三个条件还是满足其中一个就可以提取啊

满足一个就可以
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-14 15:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表