鱼C论坛

 找回密码
 立即注册
查看: 1628|回复: 0

python筛选数据

[复制链接]
发表于 2022-6-15 11:21:41 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 编程小白艾雪儿 于 2022-6-15 11:23 编辑

想要按 “发行人省份.xlsx” 中的不同省份,对 ”新发行债券_20220610.xlsx“ 进行筛选,
但在进行匹配的第16行  ” FF = data.loc[data['发行人省份'] == rowdate] ” 出现了错误,还找不到原因555
import pandas as pd
import xlrd

dir = r"C:\Users\liqian6\Desktop\RPA工作\全量表数据&母子公司对应关系"#设置工作路径

#选择发行人省份.xlsx的表,按其第一列的数对新发行债券_20220610.xlsx进行筛选
workxls =xlrd.open_workbook(dir+"\"+'发行人省份.xlsx')
worksheet = workxls.sheet_by_name("Sheet1")
row =worksheet.nrows#总行数
for i in range(1,2):
    rowdate =worksheet.row_values(i)  
    print(rowdate)
    
    #读取新发行债券_20220610.xlsx,按不同省份对其进行筛选
    data = pd.read_excel(dir + "\" + '新发行债券-0610\新发行债券_20220610.xlsx')
    FF = data.loc[data['发行人省份'] == rowdate]    

    FF.to_excel(dir + "\" + rowdate + '_20220610.xlsx', engine='xlsxwriter', index = False)
    
    print( rowdate+' is successful')

错误情况:
Traceback (most recent call last):

  File "C:\Users\liqian6\Desktop\python\python办公自动化_应用\01excel\2. excel筛选数据形成新表.py", line 20, in <module>
    FF = data.loc[data['发行人省份'] == rowdate]

  File "C:\Users\liqian6\Anaconda3\lib\site-packages\pandas\core\ops\common.py", line 69, in new_method
    return method(self, other)

  File "C:\Users\liqian6\Anaconda3\lib\site-packages\pandas\core\arraylike.py", line 32, in __eq__
    return self._cmp_method(other, operator.eq)

  File "C:\Users\liqian6\Anaconda3\lib\site-packages\pandas\core\series.py", line 5502, in _cmp_method
    res_values = ops.comparison_op(lvalues, rvalues, op)

  File "C:\Users\liqian6\Anaconda3\lib\site-packages\pandas\core\ops\array_ops.py", line 261, in comparison_op
    raise ValueError(

ValueError: ('Lengths must match to compare', (9370,), (1,))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-17 21:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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