【问题标题】:Add multiple csv in a single csv sheet in tabs using Pandas使用 Pandas 在选项卡中的单个 csv 表中添加多个 csv
【发布时间】:2018-11-04 10:38:44
【问题描述】:

我有多个 csv 文件,比如说 a.csv , b.csv 。我想要新的 c.csv 中的 a.csv 和 b.csv 。两个新的 csv 都应该在里面的选项卡中。我只想在 tabs 中添加两个 csv 。在熊猫中有没有什么捷径可以做到这一点。我有下面的代码,但它没有给出任何输出,但是它正在执行。尝试检查 stackoverflow 中的一些帖子,但不知何故我没有得到想要的输出。请帮助我找到更好的解决方案。

folders=next(os.walk('.'))[1]
for host in folders:
    Path=os.path.join(os.getcwd(),host)                    
    all_files = glob.glob(os.path.join(Path, "*.csv"))     
    df_from_each_file = (pd.read_csv(f) for f in all_files)
    df   = pd.concat(df_from_each_file, ignore_index=True)
    df.to_csv('c.csv,' index=False)

【问题讨论】:

  • "两个新的 csv 都应该在里面的选项卡中"。你这是什么意思?喜欢 CSV 中的两张不同的工作表?
  • 就像,我们想将两个现有的 csv 添加到选项卡中的新 csv 中。
  • 希望这个网址能帮到你stackoverflow.com/questions/29615196/…
  • 很有用,但没有从中弄清楚。寻找熊猫解决方案。
  • 您是否在寻找 Excel 工作簿中的“标签”?如果是这样,你不能用 CSV 来做到这一点。

标签: python excel python-3.x pandas csv


【解决方案1】:

CSV 文件实际上只是一张纸。 Excel xlsx 文件虽然支持工作表。可以使用ExcelWriter 使 Pandas 直接写入 Excel 文件。像下面这样的东西应该可以满足您的需要:

import pandas as pd
import xlsxwriter
import glob
import os

writer = pd.ExcelWriter('multi_sheet.xlsx', engine='xlsxwriter')
folders = next(os.walk('.'))[1]

for host in folders:
    Path = os.path.join(os.getcwd(), host)

    for f in glob.glob(os.path.join(Path, "*.csv")):
        print(f)
        df = pd.read_csv(f)
        df.to_excel(writer, sheet_name=os.path.basename(f)[:31])

writer.save()

对于在您的文件夹中找到的每个 CSV 文件,将创建一个新的 Excel 工作表。工作表的名称是 CSV 文件的名称,例如a.csv 的工作表名称为 a

注意:Excel 的工作表名称限制为 31 个字符。

【讨论】:

  • 2个简历的excel中是否会有两个标签?我想它只有一个?抱歉问这个我在外面我只能在一段时间后测试。
  • 每个 CSV 文件将获得一张纸。
  • 有什么办法让工作表的名字超过 31 个字符?
  • 这似乎是 Excel 中的一个限制。如果您的文件名较长,则至少需要改用[:31]。我已经更新了脚本。
猜你喜欢
  • 2017-06-23
  • 1970-01-01
  • 2018-10-19
  • 2021-05-29
  • 1970-01-01
  • 2018-04-13
  • 2019-01-28
  • 2021-04-07
  • 2019-03-17
相关资源
最近更新 更多