在 python-docx 裡有兩個東西都叫 Document,但它們角色不同:
- from docx import Document
這個 Document 通常是「入口函式(factory function)」:
用來 建立空白文件 或 讀取 docx。 - from docx.document import Document
這個 Document 才是「真正的類別(class/type)」:
用來做 isinstance() 判斷、type hint。
因此才會出現常見錯誤:把函式拿去當 isinstance() 的第二參數。
最推薦的寫法:用別名把角色分清楚
from docx import Document as load_doc
from docx.document import Document as DocxDocument
# 讀/建文件:用 load_doc
doc = load_doc()
# 判斷型別:用 DocxDocument
print(type(doc))
print(isinstance(doc, DocxDocument)) # True可以在 Jupyter 直接驗證(會印出函式 vs 類別)
from docx import Document
from docx.document import Document as DocxDocument
print("Document =", Document)
print("type(Document) =", type(Document))
doc = Document()
print("type(doc) =", type(doc))
print("isinstance(doc, DocxDocument) =", isinstance(doc, DocxDocument))

推薦hahow線上學習python: https://igrape.net/30afN






![Python Logging 完全指南:從基礎到實戰應用; import logging ; logging.basicConfig(level=logging.INFO, handlers=[ logging.StreamHandler(), logging.FileHandler(‘app.log’, mode=’a’, encoding=’utf-8′)] ) ; inspect.currentframe().f_code.co_name #動態取得funcName Python Logging 完全指南:從基礎到實戰應用; import logging ; logging.basicConfig(level=logging.INFO, handlers=[ logging.StreamHandler(), logging.FileHandler(‘app.log’, mode=’a’, encoding=’utf-8′)] ) ; inspect.currentframe().f_code.co_name #動態取得funcName](https://i1.wp.com/savingking.com.tw/wp-content/uploads/2025/10/20251021155823_0_c16012.png?quality=90&zoom=2&ssl=1&resize=350%2C233)



近期留言