python批量修改excel-python批量修改excel文件 xlwings(二)

python 批量修改excel

因为上一篇中,使用xlrd和xlutils修改excel,运行之后,表格格式和图片全没有了,我家小哥哥又太忙,只能自己再研究研究了。

xlwings

这两天查了python修改excel的库,蛮多,最终选择了xlwings,使用方式也很简单

全部代码如下:

# -*- coding: utf-8 -*-

import os

import xlwings as xw

def editExlXL(app, originPath, fileItem):

# 打开已经有的工作薄(支持相对路径和绝对路径)

wb = app.books.open(originPath + "/" + fileItem)

# 获取第一个sheet

sht = wb.sheets[0]

# print(sht, "sheet")

# 修改a1的值

# sht.range("a1").value = ""

for sheet in wb.sheets:

for picture in sheet.pictures:

height = picture.height

top = picture.top

# 删除指定位置的图片

if (top < 10 and height < 30):

picture.delete()

wb.save("./data/" + fileItem)

# 关闭工作薄

wb.close()

def mkdir(path):

folder = os.path.exists(path)

if not folder:

os.makedirs(path)

print("--- folder mk ---")

else:

print("--- folder exists ---")

def getFileList(path):

return os.listdir(path)

def editAll():

# 新建工作薄(只打开不新建)

app = xw.App(visible=True, add_book=False)

# wb = app.books.add()

originPath = "./origin"

fileList = getFileList(originPath)

print(fileList)

# 运行之前先清空data

# if os.path.exists("./data"):

# os.removedirs("./data")

# 创建data文件夹

mkdir("./data")

for fileItem in fileList:

editExlXL(app, originPath, fileItem)

# 退出excel

app.quit()

editAll()

运行方式

把你需要修改的文件放到origin文件夹下,如果没有辛苦手动创建一下,然后按照下面方式操作

pip install xlwings

python excel_opt.py

也可以参照我的python学习专栏的其他文章运行

xlwings API Document

啰嗦时间

借用我家小哥哥的口头禅:方法总比困难多。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值