使用Excel,存在一些基础重复性的操作工作,这些在日常工作可能会浪费很多的时间,通过python,可实现一些基础的操作,帮助日常办公高效操作Excel,主要梳理如下:

1.基础包:

Pathlib:操作工作簿的路径基础包
Xlwings:操作Excel工作簿的基础包
Pandas:读写相关操作

2.涉及到的操作

  • 查看路径/移动路径
  • 新建工作簿
  • 打开已有工作簿
  • 重命名工作簿
  • 转化工作簿格式
  • 拆分工作簿
  • 合并工作簿
  • 加密工作簿

3 关键代码

3.1 移动工作簿路径

说明:只能在同一个盘幅内移动

'''
 代码1:移动工作簿
说明:移动工作簿从old_path路径移动到new_path路径
关键方法:rename()
'''
from pathlib import Path
old_path = Path('D:\\python\\test_file\\test_excel.xlsx')
new_path = Path('D:\\python\\test_table\\test_excel.xlsx')
old_path.rename(new_path)
new_path.rename(old_path)

'''

3.2 解析查看基础路径信息

说明:查看基础路径,文件格式等基础信息

'''
代码2:解析工作簿的基础路径信息
主要属性:parent;stem,name,suffix
'''

#from pathlib import Path
file_path = Path('D:\\python\\test_file\\test_excel.xlsx')
# 获取文件夹路径
path = file_path.parent
#获取文件名
file_name = file_path.name
#获取文件主名
file_stem = file_path.stem
#获取文件扩展名后缀
file_suf = file_path.suffix

print(path,file_name,file_stem,file_suf)

3.3 获取文件路径下相关文件信息

说明:根据关键词模糊匹配即可

'''
代码3:获取文件夹下所有工作簿名称
主要方法:glob
'''
from pathlib import Path
fold_path = Path('D:\\python\\test_file\\test_excel.xlsx')
#茶轴啊符合指定规则的文件或文件夹并返回路径
file_list = fold_path.glob('*xlsx')
lists = []
for i in file_list:
    file_name = i.name
    lists.append(file_name)
print(lists)

3.4 新建并保存

说明:新建工作簿,并存储到指定路径

'''
代码4:新建并保存工作路径
主要包:xlwings
主要对象:APP
主要方法:
新建:add()
保存:save()
关闭:close()
退出:quit()
'''

import xlwings as xw
#打开Excel程序
app = xw.App(visible=False,add_book=False)
#新建工作簿
workbook = app.books.add()
#保存工作簿
workbook.save('D:\\python\\test_file\\test_excel01.xlsx')
#关闭工作簿
workbook.close()
#退出Excel程序
app.quit()

3.5 打开文件

说明:打开已经保存工作簿

'''
代码5:打开一个已有的工作簿
主要包:xlwings
主要方法:open()

'''

import xlwings as xw
app = xw.App(visible=False,add_book=False)
path_text = 'D:\\python\\test_file\\test_excel.xlsx'
app.books.open(path_text)

3.6 重命名工作簿

说明:重命名现有的工作簿

'''
代码6:重命名工作簿
主要包:pathlib
主要方法:
构造新路径:withname()
执行重命名操作:rename()


'''
from pathlib import Path
old_path = Path('D:\\python\\test_file\\test_excel.xlsx')
folder_path = Path('D:\\python\\test_file\\test_excel.xlsx')
new_excel = 'myexcel.xlsx'
#替换原先路径中的文件名,得出新的路径
new_file_path = folder_path.with_name(new_excel)
#移动路径
old_path.rename(new_file_path)

3.7 修改文件格式

说明:修改现有文件的文件格式,类似另存为新文件;这里分成两段代码说明相关函数的适用方法

'''
代码7:修改文件格式
主要方法:
修改文件后缀:with_suffix()
另存为:SaveAs()
'''
from pathlib import Path
import xlwings as xw
old_path = Path('D:\\python\\test_file\\test_excel.xlsx')
app = xw.App(visible=False,add_book=False)
# 修改文件格式,并转化为字符串对象
new_file_path01 = str(old_path.with_suffix('.xls'))
workbook = app.books.open(old_path)
workbook.api.SaveAs(new_file_path01,FileFormat=56)
workbook.close()
app.quit()

# 第二段代码
from pathlib import Path
import xlwings as xw
old_path = Path('D:\\python\\test_file\\test_excel.xlsx')
app = xw.App(visible=False,add_book=False)
new_file_path = 'D:\\python\\test_file\\new_excel.xls'
workbook = app.books.open(old_path)
workbook.api.SaveAs(new_file_path,FileFormat=56)
workbook.close()
app.quit()

3.8 多个sheet拆分为新Excel

说明:即一个Excel里的sheet表新建成多个Excel

'''
代码8:多个表格sheet表拆分为新工作簿
主要函数:
复制表格:copy()
'''
import xlwings as xw
app = xw.App(visible=False,add_book=False)
file_path = 'D:\\python\\test_file\\sheets_excel.xlsx'
workbook = app.books.open(file_path)
worksheet = workbook.sheets
for i in worksheet:
    # 新建工作簿
    new_workbook = app.books.add()
    # 新建工作簿sheet
    new_worksheet = new_workbook.sheets[0]
    # 将来源工作簿的当前工作表复制到新建工作簿的第一个工作表之前
    i.copy(before=new_worksheet)
    new_workbook.save('D:\\python\\test_file\\{}.xlsx'.format(i.name))
    new_workbook.close()
app.quit()

参考截图效果:

python中用路径打开文件 python打开指定路径的excel文件_后端


python中用路径打开文件 python打开指定路径的excel文件_后端_02

3.9 多个Excel合并为一个Excel

说明:将多个Excel合并为一个Excel

'''
代码9:多个工作簿合并为一个工作簿
使用包:pathlib,pandas
主要函数:
读取Excel:read_excel()
写入Excel:to_excel()
'''
from pathlib import Path
import pandas as pd
folder_path = Path('D:\\python\\test_file\\month\\')
file_list = folder_path.glob('*.xlsx*')
with pd.ExcelWriter('D:\\python\\test_file\\month\\总表.xlsx') as workbook:
    for i in file_list:
        # 获取工作簿文件名称
        stem_name = i.stem
        # 读取工作簿第一个sheet表的内容
        data = pd.read_excel(i,sheet_name=0)
        # 读取数据,写入新建的工作簿中
        data.to_excel(workbook,sheet_name=stem_name,index=False)

python中用路径打开文件 python打开指定路径的excel文件_python中用路径打开文件_03

3.10 加密工作簿

说明:对工作簿做加密处理

'''
代码10:加密保护工作簿
'''
import xlwings as xw
file_path = 'D:\\python\\test_file\\总表.xlsx'
app = xw.App(visible=False,add_book=False)
workbook = app.books.open(file_path)
workbook.api.Password = '123'
workbook.save()
workbook.close()
app.quit()

参考截图效果:

python中用路径打开文件 python打开指定路径的excel文件_python_04