Python中文
首页
教程
问答
标签
搜索
登录
注册
在具有数据帧的字典列表上循环
回答此问题可获得
20
贡献值,回答如果被采纳可获得
50
分。
<p>我有一个列表,其中包含存储为字典的输入文件,这些字典表示导入的Excel文件。每个字典都有多个表存储为数据帧</p> <p>当一列中出现三个NaN值时,我希望存储不同字典(Excel文件)的相同键(工作表)并将其相互追加,同时断开工作表。我初始化了一个新的字典,它应该与字典(Excel文件)具有相同的键(表),但现在所有数据都附加到这个字典<code>d_sheets</code></p> <p>为此,我使用以下代码:</p> <pre><code>input_files = [] for file in read_input: input_file = pd.read_excel(io=file, sheet_name=needed_sheets, dtype=str) input_files.append(input_file) d_sheets = {} for dictionary in input_files: for sheet_name in sorted(dictionary): d_sheets[sheet_name] = pd.DataFrame() if sheet_name != 'Sheetname1': cell = dictionary[sheet_name]['Columnname1'] else: cell = dictionary[sheet_name]['Columnname2'] three_NaNs = cell.isna() & cell.shift(-1).isna() & cell.shift(-2).isna() first_instance = cell[three_NaNs].index.min() good_data = dictionary[sheet_name][cell.index <= first_instance] d_sheets[sheet_name].append(good_data) d_sheets[sheet_name] = pd.concat([d_sheets[sheet_name], good_data], axis=0) </code></pre> <p>对于单个字典(Excel文件),布尔语句执行其工作,键存储在<code>d_sheets</code>中。然而,我找不到一种有效的方法来循环使用<code>input_files</code>中的词典</p> <p>是什么原因导致我无法迭代列表<code>input_files</code>中的项目并将所有工作表存储在<code>d_sheets</code>中</p>
0 条评论
分类:
Python问答
请先
登录
后评论
默认排序
时间排序
1 个回答
匿名
1天前
擅长:python、mysql、java
<p>我已经解决了这个问题,因为数据帧初始化不应该在<code>d_sheets[sheet_name] = pd.DataFrame()</code>中的for循环中。这样,循环的每次迭代都会清除数据帧,然后执行计算。最后,这将导致最新的Excel文件仅作为输出,而不是合并所有文件</p>
请先
登录
后评论
针对此问题:
更多的回答
关注
89
关注
收藏
1
收藏,
216
浏览
网友 提问于 2天前
相关Python问题
尽管Python中的所有内容都是引用,为什么Python导师在没有指针的列表中绘制字符串和整数?
6 回答
尽管python中的表达式为false,但循环仍在运行
9 回答
尽管python代码正确,但从nifi ExecuteScript处理器获取语法错误
4 回答
尽管Python在Neovim中工作得很好,但插件不能识别Neovim中的Python主机
4 回答
尽管python字典包含了大量的条目,但它并没有增长
7 回答
尽管python说模块存在,为什么我会得到这个消息?
7 回答
尽管setuptools和控制盘是最新的,但无法识别singleversionexternallymanaged
8 回答
尽管stdout和stderr重定向,但未捕获错误消息
10 回答
尽管Tensorboard的事件太大,但Tensorboard的步骤太少了
5 回答
尽管tkinter上的变量已更改,但显示未更改
4 回答
尽管try/except使用Python进行单元测试时出现断言错误
9 回答
尽管URL是sam,但仍会抛出“达到最大重定向”
4 回答
尽管url有效,Pandas仍读取url的\u csv错误
5 回答
尽管while中存在时间延迟,但LINUX线程的CPU利用率为100%(1)
9 回答
尽管x0在范围内,Scipy优化仍会引发ValueError
1 回答
尽管xpath正确,但使用selenium单击链接仍不起作用
7 回答
尽管下载了ffmpeg并设置了路径变量python,但没有后端错误
4 回答
尽管下载了i,但找不到型号“fr”
5 回答
尽管下载了plotnine包,但未获取名为“plotnine”的模块时出错
9 回答
尽管为所有行指定了权重,网格(0)仍不起作用
5 回答