python用win32com实现从excel复制表格到word

系统 3516 0
            
              def copy_table_from_excel_to_word():
    import time
    from win32com import client

    excel = client.Dispatch('Excel.Application')
    word = client.Dispatch('Word.Application')

    doc = word.Documents.Open('C:\\Users\\Administrator\\Desktop\\test.docx')
    wb = excel.Workbooks.Open('C:\\Users\\Administrator\\Desktop\\tav.xlsx')
    sheet = wb.Worksheets(1)

    tn = sheet.Cells(2, 1).value
    start_row = 2
    end_row = 2
    # 循环 把Excel第一列值一样的选中复制到word中
    while True:
        if sheet.Cells(start_row, 1).value = '':
            print('finish')
            break
        if sheet.Cells(end_row + 1, 1).value == tn:
            end_row += 1
        else:
            print(tn)
            word.Selection.InsertAfter('\n%s\n' % tn)
            word.Selection.InsertAfter('%s\n' % sheet.Cells(start_row, 2).value)
            time.sleep(0.3)
            _ = word.Selection.MoveRight()
            time.sleep(0.3)
            _ = sheet.Range('C1:H1').Copy()
            word.Selection.PasteExcelTable(False, True, False)
            time.sleep(0.3)
            _ = sheet.Range('C%d:H%d' % (start_row, end_row)).Copy()
            word.Selection.PasteExcelTable(False, True, False)
            time.sleep(0.3)
            
            start_row = end_row + 1
            end_row += 1
            tn = sheet.Cells(start_row, 1).value

    doc.Close()
    wb.Close()
            
          

com对象的各种属性和方法参考:

https://docs.microsoft.com/zh-CN/office/vba/api/word.paragraphformat


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论