使用python,选择文件夹,将文件夹内所有个工作簿内的所有工作表移动至一个新工作簿中并保存至桌面,并用“业务台账”+当天日期的格式命名新工作簿

时间: 2023-05-15 13:06:48 浏览: 22
可以使用Python中的pandas和openpyxl库来实现这个任务。以下是代码示例: ```python import os import pandas as pd from openpyxl import Workbook, load_workbook from datetime import datetime # 选择文件夹路径 folder_path = input("请输入文件夹路径:") # 获取所有Excel文件的路径 file_paths = [] for root, dirs, files in os.walk(folder_path): for file in files: if file.endswith(".xlsx"): file_paths.append(os.path.join(root, file)) # 创建新工作簿 new_wb = Workbook() # 遍历所有Excel文件,将所有工作表复制到新工作簿中 for file_path in file_paths: wb = load_workbook(file_path) for sheet_name in wb.sheetnames: sheet = wb[sheet_name] df = pd.DataFrame(sheet.values) df.columns = df.iloc[0] df = df.iloc[1:] sheet_data = [df.columns.tolist()] + df.values.tolist() new_sheet = new_wb.create_sheet(sheet_name) for row in sheet_data: new_sheet.append(row) # 保存新工作簿至桌面 desktop_path = os.path.join(os.path.expanduser("~"), "Desktop") today = datetime.today().strftime('%Y%m%d') new_file_name = f"业务台账{today}.xlsx" new_file_path = os.path.join(desktop_path, new_file_name) new_wb.save(new_file_path) print(f"已将文件夹内所有工作簿内的所有工作表移动至新工作簿并保存至桌面:{new_file_path}") ``` 这个代码会提示你输入文件夹路径,然后会遍历文件夹内所有的Excel文件,将所有工作表复制到一个新的工作簿中,并将新工作簿保存至桌面,文件名为“业务台账”加上当天日期的格式。

相关推荐

您可以使用Python中的pandas库来读取和合并多个Excel工作簿。以下是一个示例代码,可以将一个文件夹中的多个Excel工作簿合并为一个工作表,并保持原有的格式: python import os import pandas as pd # 设置要读取的文件夹路径和工作表名称 folder_path = 'folder_path' sheet_name = 'Sheet1' # 定义一个空的DataFrame,用于存储所有工作簿数据 all_data = pd.DataFrame() # 循环遍历文件夹中的所有Excel文件,并将数据添加到all_data中 for file_name in os.listdir(folder_path): # 判断文件是否为Excel文件 if file_name.endswith('.xlsx') or file_name.endswith('.xls'): # 读取工作簿文件中的数据 file_path = os.path.join(folder_path, file_name) df = pd.read_excel(file_path, sheet_name=sheet_name) # 将读取的数据添加到all_data中 all_data = all_data.append(df, ignore_index=True) # 将合并后的数据保存到一个新的Excel工作簿中 writer = pd.ExcelWriter('merged_file.xlsx') all_data.to_excel(writer, sheet_name=sheet_name, index=False) writer.save() 在这个示例代码中,首先定义了要读取的文件夹路径和工作表名称,然后使用os库的listdir()函数循环遍历文件夹中的所有Excel文件。对于每个Excel文件,使用pandas库的read_excel()函数读取其中的数据,并将其添加到一个空的DataFrame对象中。最后,使用pandas库的to_excel()函数将合并后的数据保存到一个新的Excel工作簿中。 需要注意的是,这种方法可能会导致合并后的工作表格式不一致,因为不同的工作簿可能具有不同的格式和样式。如果需要保持每个工作簿的格式和样式不变,可能需要使用其他一些库和方法,例如openpyxl库或xlwings库。
### 回答1: 可以使用Python中的pandas和openpyxl库来实现这个功能。 首先,需要安装pandas和openpyxl库。可以在命令行中使用以下命令安装: pip install pandas openpyxl 然后,可以使用以下代码来实现将同一个文件夹中所有文件汇总到一个工作簿中,并以原文件名称命名各个sheet: python import os import pandas as pd from openpyxl import Workbook # 获取文件夹路径 folder_path = r"path/to/folder" # 获取文件夹中所有文件名 files = os.listdir(folder_path) # 创建一个新的工作簿 wb = Workbook() # 循环遍历每个文件 for file in files: # 读取文件内容为DataFrame df = pd.read_excel(os.path.join(folder_path, file)) # 将DataFrame写入新的sheet,以文件名命名 wb.create_sheet(title=file) ws = wb[file] for r in dataframe_to_rows(df, index=False, header=True): ws.append(r) # 保存工作簿 wb.save('combined.xlsx') 这段代码将会将文件夹中的所有Excel文件读取为DataFrame,并将它们写入到一个新的工作簿中。每个文件对应一个sheet,并以原文件名称命名。最后,保存工作簿为combined.xlsx。 ### 回答2: 要将同一个文件夹里面的所有文件汇总到一个工作簿中,并以原文件名称命名各个sheet,可以按照以下步骤进行操作: 1. 打开Excel软件,并创建一个新的工作簿。 2. 在工作簿的第一个sheet中,输入表头,即各列的字段名称,例如文件名、日期、作者等等。 3. 使用VBA宏编程实现自动汇总。按下"Alt + F11"快捷键,打开VBA编辑器。 4. 在VBA编辑器中,插入一个新的模块,然后在模块中编写以下代码: vba Sub 汇总文件夹中的文件() Dim 文件夹路径 As String Dim 文件名 As String Dim 文件数量 As Integer 文件夹路径 = "C:\文件夹路径\" 文件名 = Dir(文件夹路径 & "*.xlsx") 文件数量 = 2 '从第二行开始输入数据 Do While 文件名 <> "" Workbooks.Open (文件夹路径 & 文件名) ActiveSheet.Copy After:=ThisWorkbook.Sheets(ThisWorkbook.Sheets.Count) ThisWorkbook.Sheets(ActiveSheet.Name).Name = Left(文件名, Len(文件名) - 5) '以原文件名命名sheet ActiveWorkbook.Close True 文件名 = Dir 文件数量 = 文件数量 + 1 Loop MsgBox "汇总完成!" End Sub 请注意修改代码中的文件夹路径,确保其与实际文件夹路径一致。上述代码中,假设文件夹路径为"C:\文件夹路径\",要汇总的文件为xlsx格式的文件。 5. 在VBA编辑器中,按下"F5"键,运行宏。 运行完毕后,所有指定文件夹中的文件就会被汇总到一个工作簿中,每个文件对应一个sheet,并以各个文件的原文件名命名每个sheet,方便查看和检索。在工作簿中,可以按照需要进行排序、筛选等操作,以方便数据处理和查看。 ### 回答3: 要实现将同一个文件夹中的所有文件汇总到一个工作簿并以原文件名称命名各个工作表,可以按照以下步骤进行操作: 1. 首先,获取文件夹中所有的文件名。 2. 创建一个新的工作簿,作为汇总结果的保存位置。 3. 遍历文件夹中的每一个文件。 4. 对于每个文件,将其打开并读取内容。 5. 在新的工作簿中创建一个新的工作表,并将该工作表以原文件名命名。 6. 将读取的文件内容复制到相应的工作表中。 7. 关闭当前文件。 8. 重复3-7步骤,直到遍历完文件夹中的所有文件。 9. 保存并关闭汇总的工作簿。 具体实现代码如下: python import os import openpyxl # 获取文件夹路径 folder_path = '文件夹路径' # 创建一个新的工作簿 workbook = openpyxl.Workbook() # 获取文件夹中的所有文件名 file_names = os.listdir(folder_path) # 遍历文件夹中的每一个文件 for file_name in file_names: # 拼接文件路径 file_path = os.path.join(folder_path, file_name) # 打开文件 with open(file_path, 'r') as file: # 读取文件内容 file_content = file.read() # 创建一个新的工作表,并以原文件名命名 sheet = workbook.create_sheet(title=file_name) # 将文件内容复制到工作表中 sheet['A1'] = file_content # 删除默认创建的工作表 workbook.remove(workbook['Sheet']) # 保存汇总的工作簿 workbook.save('汇总文件.xlsx') 将以上代码的 文件夹路径 替换为实际的文件夹路径,然后运行即可将同一个文件夹中的所有文件汇总到一个工作簿,并以原文件名称命名各个工作表。
您可以使用Python中的pandas库来读取和合并多个Excel工作簿。以下是一个示例代码,可以将多个Excel工作簿合并为一个工作表,并保持原有的格式: python import pandas as pd # 设置要读取的工作簿文件名和工作表名称 file_names = ['file1.xlsx', 'file2.xlsx', 'file3.xlsx'] sheet_name = 'Sheet1' # 定义一个空的DataFrame,用于存储所有工作簿数据 all_data = pd.DataFrame() # 逐一读取每个工作簿文件,并将数据添加到all_data中 for file_name in file_names: # 读取工作簿文件中的数据 df = pd.read_excel(file_name, sheet_name=sheet_name) # 将读取的数据添加到all_data中 all_data = all_data.append(df, ignore_index=True) # 将合并后的数据保存到一个新的Excel工作簿中 writer = pd.ExcelWriter('merged_file.xlsx') all_data.to_excel(writer, sheet_name=sheet_name, index=False) writer.save() 在这个示例代码中,首先定义了要读取的工作簿文件名和工作表名称,然后使用pandas库的read_excel()函数逐一读取每个工作簿文件中的数据,并将其添加到一个空的DataFrame对象中。最后,使用pandas库的to_excel()函数将合并后的数据保存到一个新的Excel工作簿中。 需要注意的是,这种方法可能会导致合并后的工作表格式不一致,因为不同的工作簿可能具有不同的格式和样式。如果需要保持每个工作簿的格式和样式不变,可能需要使用其他一些库和方法,例如openpyxl库或xlwings库。
### 回答1: 可以使用Python中的openpyxl库来实现。首先需要导入该库: python import openpyxl 然后,读取表格文件并获取工作簿的名称: python # 打开Excel文件 workbook = openpyxl.load_workbook('example.xlsx') # 获取当前工作表名称 sheet_name = workbook.active.title 接着,创建文件夹并以工作簿名称命名: python import os # 创建文件夹 os.makedirs(sheet_name, exist_ok=True) 最后,保存并关闭Excel文件: python # 保存Excel文件 workbook.save('example.xlsx') # 关闭Excel文件 workbook.close() 完整代码如下: python import os import openpyxl # 打开Excel文件 workbook = openpyxl.load_workbook('example.xlsx') # 获取当前工作表名称 sheet_name = workbook.active.title # 创建文件夹 os.makedirs(sheet_name, exist_ok=True) # 保存Excel文件 workbook.save('example.xlsx') # 关闭Excel文件 workbook.close() 注意:此代码仅适用于已经存在的Excel文件。如果要从头开始创建Excel文件并设置工作簿名称,请参考openpyxl文档中的相关章节。 ### 回答2: 通过Python获取表格工作簿的名称并根据名称创建文件夹可以使用openpyxl库进行操作。下面是一种实现方法: 首先,需要安装openpyxl库。可以使用以下命令进行安装: python pip install openpyxl 接下来,导入openpyxl库并进行相关操作: python import os from openpyxl import load_workbook # 导入工作簿 workbook = load_workbook('example.xlsx') # 获取所有的工作表 sheets = workbook.sheetnames # 遍历工作表 for sheet_name in sheets: # 创建文件夹 folder_name = sheet_name.replace('/', '-') # 创建文件夹的路径 folder_path = os.path.join(os.getcwd(), folder_name) # 判断文件夹是否存在 if not os.path.exists(folder_path): os.makedirs(folder_path) 上述代码中,第2行导入了所需的库。第5行使用load_workbook函数导入了Excel文件(例子中文件名为"example.xlsx"),然后使用sheetnames属性获取所有工作表的名称。 接下来,使用for循环遍历所有的工作表名称。在循环中,第11行将工作表名称中的特殊字符(例如"/")替换为"-",并将该名称作为文件夹名称。第14行根据文件夹名称创建文件夹的路径。最后,判断文件夹是否存在,如果不存在,则使用makedirs函数创建文件夹。 通过以上代码,你可以实现根据表格工作簿的名称创建文件夹的功能。 ### 回答3: 在Python中获取表格工作簿的名称并根据名称创建文件夹,可以使用openpyxl库来实现。下面是具体的步骤: 1. 首先,安装openpyxl库,可以使用pip命令在命令行中执行:pip install openpyxl。 2. 导入所需的模块,代码如下: import openpyxl import os 3. 使用openpyxl库的load_workbook()函数打开Excel文件,代码如下: workbook = openpyxl.load_workbook('your_file.xlsx') 其中'your_file.xlsx'是你所要打开的Excel文件名,确保该文件与你的Python程序在同一目录下。 4. 获取工作表的所有名称,代码如下: sheet_names = workbook.sheetnames 5. 使用os库的mkdir()函数创建文件夹,代码如下: for name in sheet_names: os.mkdir(name) 这样,根据工作簿中的每个名称,在当前目录下将会创建对应的文件夹。 完整的代码如下: import openpyxl import os workbook = openpyxl.load_workbook('your_file.xlsx') sheet_names = workbook.sheetnames for name in sheet_names: os.mkdir(name) 上述代码中的'your_file.xlsx'需要替换为你的实际文件名,另外确保代码和要打开的Excel文件在同一目录下。

最新推荐

python利用openpyxl拆分多个工作表的工作簿的方法

主要介绍了python利用openpyxl拆分多个工作表的工作簿的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

代码随想录最新第三版-最强八股文

这份PDF就是最强⼋股⽂! 1. C++ C++基础、C++ STL、C++泛型编程、C++11新特性、《Effective STL》 2. Java Java基础、Java内存模型、Java面向对象、Java集合体系、接口、Lambda表达式、类加载机制、内部类、代理类、Java并发、JVM、Java后端编译、Spring 3. Go defer底层原理、goroutine、select实现机制 4. 算法学习 数组、链表、回溯算法、贪心算法、动态规划、二叉树、排序算法、数据结构 5. 计算机基础 操作系统、数据库、计算机网络、设计模式、Linux、计算机系统 6. 前端学习 浏览器、JavaScript、CSS、HTML、React、VUE 7. 面经分享 字节、美团Java面、百度、京东、暑期实习...... 8. 编程常识 9. 问答精华 10.总结与经验分享 ......

无监督人脸特征传输与检索

1检索样式:无监督人脸特征传输与检索闽金虫1号mchong6@illinois.edu朱文生wschu@google.comAbhishek Kumar2abhishk@google.com大卫·福赛斯1daf@illinois.edu1伊利诺伊大学香槟分校2谷歌研究源源源参考输出参考输出参考输出查询检索到的图像(a) 眼睛/鼻子/嘴(b)毛发转移(c)姿势转移(d)面部特征检索图1:我们提出了一种无监督的方法来将局部面部外观从真实参考图像转移到真实源图像,例如,(a)眼睛、鼻子和嘴。与最先进的[10]相比,我们的方法能够实现照片般逼真的传输。(b) 头发和(c)姿势,并且可以根据不同的面部特征自然地扩展用于(d)语义检索摘要我们提出检索风格(RIS),一个无监督的框架,面部特征转移和检索的真实图像。最近的工作显示了通过利用StyleGAN潜在空间的解纠缠特性来转移局部面部特征的能力。RIS在以下方面改进了现有技术:1)引入

HALCON打散连通域

### 回答1: 要打散连通域,可以使用 HALCON 中的 `connection` 和 `disassemble_region` 函数。首先,使用 `connection` 函数将图像中的连通域连接起来,然后使用 `disassemble_region` 函数将连接后的连通域分离成单独的区域。下面是一个示例代码: ``` read_image(Image, 'example.png') Threshold := 128 Binary := (Image > Threshold) ConnectedRegions := connection(Binary) NumRegions :=

数据结构1800试题.pdf

你还在苦苦寻找数据结构的题目吗?这里刚刚上传了一份数据结构共1800道试题,轻松解决期末挂科的难题。不信?你下载看看,这里是纯题目,你下载了再来私信我答案。按数据结构教材分章节,每一章节都有选择题、或有判断题、填空题、算法设计题及应用题,题型丰富多样,共五种类型题目。本学期已过去一半,相信你数据结构叶已经学得差不多了,是时候拿题来练练手了,如果你考研,更需要这份1800道题来巩固自己的基础及攻克重点难点。现在下载,不早不晚,越往后拖,越到后面,你身边的人就越卷,甚至卷得达到你无法想象的程度。我也是曾经遇到过这样的人,学习,练题,就要趁现在,不然到时你都不知道要刷数据结构题好还是高数、工数、大英,或是算法题?学完理论要及时巩固知识内容才是王道!记住!!!下载了来要答案(v:zywcv1220)。

无监督身份再识别中的判别表示学习算法及领域适应技术的研究与应用

8526基于判别表示学习的无监督身份再识别Takashi Isobe1,2,Dong Li1,Lu Tian1,Weihua Chen3,Yi Shan1,ShengjinWang2*1 Xilinx Inc.,中国北京2清华大学3阿里巴巴集团{dongl,lutian,yishan}@xilinx.comjbj18@mails.tsinghua.edu.cnwgsg@tsinghua.edu.cnkugang. alibaba-inc.com摘要在这项工作中,我们解决的问题,无监督域适应的人重新ID注释可用于源域,但不为目标。以前的方法通常遵循两阶段优化管道,其中网络首先在源上进行预训练,然后使用通过特征聚类创建的伪标签在目标上进行微调。这种方法存在两个主要局限性。(1)标签噪声可能阻碍用于识别目标类别的区分特征的学习。(2)领域差距可能会阻碍知识从源到目标的转移。我们提出了三种技术方案来缓解(一)(b)第(1)款(c)第(1)款这些问题首先,我们提出了一个集群明智的对比学习算法(CCL)的特征学习和集群精炼的迭代优�

开路电压、短路电流测等效内阻的缺点

### 回答1: 开路电压、短路电流测等效内阻的缺点有以下几个: 1. 受环境条件影响较大:开路电压、短路电流测等效内阻需要在特定的环境条件下进行,如温度、湿度等,如果环境条件发生变化,测量结果可能会出现较大误差。 2. 测量精度较低:开路电压、短路电流测等效内阻的精度受到仪器精度、线路接触不良等因素的影响,误差较大。 3. 需要断开电池电路:开路电压、短路电流测等效内阻需要断开电池电路进行测量,这样会导致电池的使用受到影响,对于某些需要连续供电的设备来说不太适用。 4. 无法检测内部故障:开路电压、短路电流测等效内阻只能检测电池整体的性能,无法检测到电池内部的故障,如单体电池损坏等问

TFT屏幕-ILI9486数据手册带命令标签版.pdf

ILI9486手册 官方手册 ILI9486 is a 262,144-color single-chip SoC driver for a-Si TFT liquid crystal display with resolution of 320RGBx480 dots, comprising a 960-channel source driver, a 480-channel gate driver, 345,600bytes GRAM for graphic data of 320RGBx480 dots, and power supply circuit. The ILI9486 supports parallel CPU 8-/9-/16-/18-bit data bus interface and 3-/4-line serial peripheral interfaces (SPI). The ILI9486 is also compliant with RGB (16-/18-bit) data bus for video image display. For high speed serial interface, the ILI9486 also provides one data and clock lane and supports up to 500Mbps on MIPI DSI link. And also support MDDI interface.

无监督人员身份再识别中的Meta成对关系蒸馏方法

3661Meta成对关系蒸馏的无监督人员身份再识别浩轩叶季1王乐1 * 周三平1唐伟2南宁郑1刚华31西安交通大学人工智能与机器人研究所2美国伊利诺伊大学芝加哥分校摘要由于缺乏地面真实标签,无监督人员重新识别(Re-ID)仍然具有挑战性。现有方法通常依赖于经由迭代聚类和分类估计的伪标签,并且不幸的是,它们非常容易受到由不准确的估计的聚类数量引起的性能损失的影响另外,我们提出了Meta Pairwise RelationshipDistillation(MPRD)方法来估计无监督人Re-ID的样本对的伪标签。具体地,它由卷积神经网络(CNN)和图卷积网络(GCN)组成,其中GCN基于由CNN提取的当前特征来估计样本对的伪标签,并且CNN通过涉及由GCN施加的高保真正样本和负样本对来学习更好的为了实现这一目标,少量的标记样本用于指导GCN训练,它可以提取Meta知识来判断正负样本对之间的�

使用 easyx 绘制先序遍历的 C++ 代码,并在遍历时改变遍历的节点的颜色。

### 回答1: 以下是使用 easyx 绘制先序遍历并改变节点颜色的 C++ 代码: ```cpp #include <graphics.h> #include <conio.h> #include <iostream> #include <stack> using namespace std; const int MAXN = 105; // 最大节点数 const int nodeSize = 30; // 节点大小 const int interval = 50; // 节点间距 int n;