作品介绍
作品名称:自动复制一个工作簿的所有工作表到其他工作簿
开发环境:PyCharm 2023.3.4 + python3.7
用到的库:os、xlwings
作品效果:
实现过程
一、代码设计
以下是代码的详细说明:
- 导入模块:
-
import os
:导入Python的操作系统接口模块,用于处理文件和目录。 -
import xlwings as xw
:导入xlwings
库,这是一个可以操作Excel的Python库。
- 定义函数:
def copy_data(direct, src)
:定义了一个名为copy_data
的函数,它接受两个参数:direct
(目标目录的路径)和src
(源工作簿的路径)。
- 检查目录和文件:
-
使用
os.path.isdir(direct)
检查direct
是否是一个有效的目录。 -
使用
os.path.exists(src)
检查src
路径的文件是否存在。
- 启动Excel应用:
app = xw.App(visible=False, add_book=False)
:启动Excel应用,设置为不显示界面,并且不添加新的工作簿。
- 加载工作簿和工作表:
-
workbook = app.books.open(src)
:打开源工作簿。 -
worksheet = workbook.sheets
:获取源工作簿中的所有工作表。
- 遍历目标目录中的文件:
-
for i in os.listdir(direct)
:遍历direct
目录中的所有文件。 -
if os.path.splitext(i)[1] == '.xlsx'
:检查文件扩展名是否为.xlsx
。
- 打开目标工作簿并复制工作表:
-
workbooks = app.books.open(os.path.join(direct, i))
:打开目标目录中的.xlsx
文件。 -
for j in worksheet
:遍历源工作簿中的所有工作表。 -
contents = j.range('A1').expand('table').value
:获取工作表j
从A1开始的表格数据。 -
workbooks.sheets.add(name=name, after=len(workbooks.sheets))
:在目标工作簿中添加一个新的工作表,并命名为源工作表的名称。 -
workbooks.sheets[name].range('A1').value = contents
:将复制的数据粘贴到新添加的工作表的A1单元格开始的位置。
- 保存并关闭工作簿:
workbooks.save()
:保存目标工作簿的更改。
- 异常处理:
except Exception as e
:捕获并打印出在执行过程中发生的任何异常。
- 清理资源:
-
finally
:无论是否发生异常,都会执行的代码块。 -
for book in app.books
:遍历所有打开的工作簿并关闭它们。 -
app.quit()
:退出Excel应用。
- 设置路径并调用函数:
-
设置
directory_path
和file_path
变量。 -
调用
copy_data(directory_path, file_path)
函数执行复制操作。
“”" 自动复制一个工作簿的所有工作表到其他工作簿 “”" import os import xlwings as xw
def copy_data(direct, src):
if not os.path.isdir(direct):
print(‘指定的路径不是一个目录’)
return
if not os.path.exists(src):
print(‘文件路径不正确,请检查’)
return
# 启动Excel应用,不显示界面
app = xw.App(visible=False, add_book=False)
try:
# 加载工作簿
workbook = app.books.open(src)
worksheet = workbook.sheets
for i in os.listdir(direct):
if os.path.splitext(i)[1] == ‘.xlsx’:
workbooks = app.books.open(os.path.join(direct, i))
for j in worksheet:
# 添加新的工作表
contents = j.range(‘A1’).expand(‘table’).value
name = j.name
workbooks.sheets.add(name=name, after=len(workbooks.sheets))
workbooks.sheets[name].range(‘A1’).value = contents
workbooks.save()
except Exception as e:
print(f"错误信息: {e}")
finally:
# 关闭所有打开的工作簿
for book in app.books:
book.close()
# 关闭Excel实例
app.quit()directory_path = ‘./目录’ file_path = ‘./汇总表.xlsx’
copy_data(directory_path, file_path)
The End
这篇文章到这里就结束了,主要还是介绍一些ADB以及图像相关的基础操作。谢谢大家的观看。
同时我也为大家整理好了python入门的学习基本语法,可以帮大家省下不少时间。
全套PDF电子书
书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。
如果你想要入门python,给大家准备了一份:282G全网最全的python资料包免费领取!
结语
对于已经走上转行道路的同学,不要再去在意网上的各种言论,请坚定地走下去。考虑那些负面的消息和情绪对你当下的情况已没有任何帮助。这个时候我们只有去想每个问题该如何解决,自己还欠缺什么。如果说环境不好,就业岗位少,就去琢磨那些找到工作的人有什么优势,自己如何弥补,而不是抱怨大环境。接受现实,努力适应,是能改善现状的唯一办法。
获取方式: