欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python讀取HTML中的canvas并且以圖片形式存入Word文檔

 更新時間:2022年08月15日 17:07:01   作者:小小明-代碼實體  
這篇文章主要介紹了Python讀取HTML中的canvas并且以圖片形式存入Word文檔,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下

前言

朋友提問:

創(chuàng)建Word文檔并插入

市面上有很多圖表繪制庫,例如echarts和highcharts等等。對于這種由js動態(tài)繪制的圖表,我們只能控制游覽器自動截圖存入word,

完整代碼如下:

from docx import Document
import os
from selenium import webdriver

browser = webdriver.Chrome()
# 調(diào)整游覽器大小達到調(diào)整圖表寬度的目的
browser.set_window_size(540, 1024)
url = "file://" + \
    os.path.abspath("html/awrcrt_MESDB_1_21369_21373.html").replace("\\", "/")
browser.get(url)

doc = Document()
for canvas in browser.find_elements_by_tag_name("canvas"):
    canvas.location_once_scrolled_into_view
    canvas.screenshot("tmp.png")
    doc.add_picture("tmp.png")
doc.save("img.docx")

然后我們得到Word文檔:

插入到已存在的Word文檔指定的位置

后面朋友又反饋,只需要插入HTML中的指定幾張圖表到現(xiàn)有Word文檔的指定位置。

待插入的圖表元素都有對應的ID可以定位:

那我們只需要對Word文檔要插入的位置進行標記,模板如下:

然后完整代碼如下:

from docx.shared import Mm
from docxtpl import DocxTemplate, InlineImage
from docx import Document
import os
from selenium import webdriver

browser = webdriver.Chrome()
# 調(diào)整游覽器大小達到調(diào)整圖表寬度的目的
browser.set_window_size(540, 1024)
url = "file://" + \
    os.path.abspath("html/awrcrt_MESDB_1_21369_21373.html").replace("\\", "/")
browser.get(url)

tpl = DocxTemplate("數(shù)據(jù)庫性能概覽_模板.docx")
canvas_ids = ["canvas_cpu", "canvas_conn",
              "canvas_commit", "canvas_logon", "canvas_event"]
context = {}
context["dbname"] = "MESDB"
for canvas_id in canvas_ids:
    canvas = browser.find_element_by_id(canvas_id)
    canvas.location_once_scrolled_into_view
    canvas.screenshot(f"{canvas_id}.png")
    context[canvas_id] = InlineImage(tpl, f"{canvas_id}.png", width=Mm(165))
tpl.render(context)
tpl.save("數(shù)據(jù)庫性能概覽.docx")
browser.close()

生成結果:

到此這篇關于Python讀取HTML中的canvas并且以圖片形式存入Word文檔的文章就介紹到這了,更多相關Python讀取canvas內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 關于python爬蟲模塊urllib庫詳解

    關于python爬蟲模塊urllib庫詳解

    這篇文章主要介紹了關于python爬蟲模塊urllib庫詳解,學習爬蟲,最初的操作便是模擬瀏覽器向服務端發(fā)出請求,這里我們就學習使用urlib庫的用法,需要的朋友可以參考下
    2023-07-07
  • Python實現(xiàn)遍歷目錄的方法【測試可用】

    Python實現(xiàn)遍歷目錄的方法【測試可用】

    這篇文章主要介紹了Python實現(xiàn)遍歷目錄的方法,涉及Python針對目錄與文件的遍歷、判斷、讀取相關操作技巧,需要的朋友可以參考下
    2017-03-03
  • 在Django中創(chuàng)建自己的自定義用戶模型

    在Django中創(chuàng)建自己的自定義用戶模型

    這篇文章主要介紹了在Django中創(chuàng)建自己的自定義用戶模型,創(chuàng)建自己的自定義用戶模型至關重要。將來,如果要對模型進行一些更改,則可以輕松進行這些更改。不然我們可能必須對模型進行一些更改,而且代碼的某些部分也將被更改,下面一起進入文章里哦阿姐個表格的詳細內(nèi)容吧
    2022-01-01
  • Python實現(xiàn)隨機創(chuàng)建電話號碼的方法示例

    Python實現(xiàn)隨機創(chuàng)建電話號碼的方法示例

    這篇文章主要介紹了Python實現(xiàn)隨機創(chuàng)建電話號碼的方法,涉及Python隨機數(shù)運算相關操作技巧,需要的朋友可以參考下
    2018-12-12
  • tf.concat中axis的含義與使用詳解

    tf.concat中axis的含義與使用詳解

    今天小編就為大家分享一篇tf.concat中axis的含義與使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 淺談Python中用datetime包進行對時間的一些操作

    淺談Python中用datetime包進行對時間的一些操作

    下面小編就為大家?guī)硪黄獪\談Python中用datetime包進行對時間的一些操作。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • Sphinx生成python文檔示例圖文解析

    Sphinx生成python文檔示例圖文解析

    這篇文章主要介為大家紹了Sphinx生成python文檔示例圖文解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪
    2022-04-04
  • Jupyter?notebook運行后打不開網(wǎng)頁的問題解決

    Jupyter?notebook運行后打不開網(wǎng)頁的問題解決

    本文主要介紹了Jupyter?notebook運行后打不開網(wǎng)頁的問題解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Python腳本打包成可執(zhí)行文件過程解析

    Python腳本打包成可執(zhí)行文件過程解析

    這篇文章主要介紹了Python腳本打包成可執(zhí)行文件過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • python讀取TXT每行,并存到LIST中的方法

    python讀取TXT每行,并存到LIST中的方法

    今天小編就為大家分享一篇python讀取TXT每行,并存到LIST中的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10

最新評論