taiyang1888 2022-10-17 15:07 采纳率: 60%
浏览 152
已结题

python 报错“ValueError: I/O operation on closed file.” openpyxl 复制粘贴图片 不能保存第二遍 在不重复读取原表的前提下,请问应该怎么改?

python openpyxl 复制粘贴图片 不能保存第二遍 报错“ValueError: I/O operation on closed file.”在不重复读取原表的前提下,请问应该怎么改?

我想把abc.xlsx的一张图片,复制粘贴到两个新表(a-abc.xlsx,b-abc.xlsx)里面
a-abc.xlsx 保存了,
b-abc.xlsx保存不到

abc.xlsx 截图:

img

代码:
import openpyxl
filename=r"F:\desk\abc.xlsx"
book = openpyxl.load_workbook(filename)
sh = book['Sheet1']
for i in ['a-','b-']: 
    print(i)
    book2 = openpyxl.Workbook()
    sh2 = book2.active
    for image in sh._images:
        sh2.add_image(image)
    filename2="F:\desk\{}abc.xlsx".format(i)
    book2.save(filename2)
    print(filename2,'已保存')

运行结果及报错内容

a-
F:\desk\a-abc.xlsx 已保存
b-


img

我想要达到的结果

怎么改?
我想把abc.xlsx的一张图片,复制粘贴到两个新表(a-abc.xlsx,b-abc.xlsx)里面
a-abc.xlsx 保存了,
但是b-abc.xlsx保存不到

  • 写回答

3条回答 默认 最新

  • honestman_ 2022-10-17 15:53
    关注

    改成这样就行了,。如果问题解决,点击一下采纳谢谢:

    import openpyxl
    for i in ['a-','b-']:
        filename = r"F:\desk\abc.xlsx"
        book = openpyxl.load_workbook(filename)
        sh = book['Sheet1']
        for image in sh._images:
            book2 = openpyxl.Workbook()
            sh2 = book2.active
            sh2.add_image(image)
            filename2="F:\desk{}abc.xlsx".format(i)
            book2.save(filename2)
            print(filename2,'已保存')
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    1人已打赏
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 10月17日
  • 已采纳回答 10月17日
  • 修改了问题 10月17日
  • 修改了问题 10月17日
  • 展开全部

悬赏问题

  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line