解决xlwings删除部分图片后,文件大小不变

背景

在使用xlwings 删除excel含有wps的嵌入式图片的部分数据时,发现无论如何删除,即使仅剩一行数据,excel的大小还是和原excel一致

解决思路

首先怀疑是xlwings 的问题,故使用openpyxl读取数据,发现文件大小虽然变小了,但是嵌入式的图片确没有保存,故放弃方法一
再者,发现手动删除某两行数据,在保存文件会变小,所以就使用xwlings删除含有图片的两行数据,保存后发现文件大小还是没有变化,经过自己思考过后才发现是因为在wps点击了保存导致,而xlwings是与office相绑定的自己手动删除后文件大小也不会变化,所以就去寻找python与wps交互的包,最终找到解决问题的代码

解决问题代码

	import win32com.client
 # 创建WPS的COM对象
    wps = win32com.client.Dispatch("KET.Application")

    # 启动WPS应用程序
    wps.Visible = False

    # 打开一个文档
    doc = wps.Workbooks.Open('xxxx.xlsx')

    # 保存并关闭文档
    doc.Save()
    doc.Close()

    # 退出WPS应用程序
    wps.Quit()

总结

还是遇到的问题太少了,需要多遇到问题,能够快速找到问题所在,从而解决问题,“革命尚未成功,同志仍需努力”

### 使用 `xlwings` 在 Excel 单元格中嵌入图片 为了在 Excel 中通过 Python 库 `xlwings` 嵌入图片到特定单元格,下面展示了具体方法。需要注意的是,虽然 `openpyxl` 支持一些高级功能如操作图表和图片[^1],但在实际应用中对于某些复杂场景可能仍需借助其他工具或库实现更灵活的操作。 要使用 `xlwings` 将图像插入到工作表中的指定位置: ```python import xlwings as xw # 打开现有工作簿或创建新的工作簿 wb = xw.Book() # 创建新工作簿 sheet = wb.sheets['Sheet1'] # 插入图片至A1单元格附近的位置(左上角坐标),调整大小适应单个单元格显示 image_path = 'path/to/your/image.png' sheet.pictures.add(image_path, name='Image_1', update=True, left=sheet.range('A1').left, top=sheet.range('A1').top, width=80, height=60) # 如果希望根据图片原始尺寸自动放置而不改变其比例,则可省略width和height参数 sheet.pictures.add(image_path, name='Original_Size_Image', left=sheet.range('B2').left, top=sheet.range('B2').top) ``` 上述代码片段首先导入了必要的模块并打开了一个新的 Excel 工作簿。接着定义了一个名为 `sheet` 的变量指向第一个工作表 (`Sheet1`) 。之后利用 `.pictures.add()` 方法向该工作表内添加了一张来自本地路径的 PNG 图像,并将其定位到了 A1 单元格旁边(即设置图片左上角与 A1 单元格左上角对齐),同时指定了宽度和高度使得它可以较好地适配于一个标准单元格之内;另外也提供了另一种方式保持原图尺寸不变而直接放置于 B2 处的例子。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值