python-docx 頁面設置詳解
初識word文檔-節-的概念
編輯一篇word文檔,往往首先從頁面設置開始,從下圖可以看出,頁面設置常操作的有頁邊距、紙張方向、紙張大小4個,而在word中是以節(section)來分大的塊,每一節的頁面設置可以不同。所以在python-docx中也是一樣,當前節的各項屬性全部保存在當前的section中,要想設置當前節的頁面就從瞭解section的各個屬性應用開始吧。
如果用python-docx新建一個空白文檔,那麼默認是隻有一個節
>>> import docx >>> doc = docx.Document() >>> len(doc.sections) 1
,如果要增加節可以用doc.add_section()來完成。
>>> import docx >>> doc = docx.Document() >>> len(doc.sections) 1 >>> doc.add_section() <docx.section.Section object at 0x000001F27F85E370> >>> len(doc.sections) 2
瞭解瞭節之後我們開始來對節的頁面進行設置。
設置頁邊距
在python-docx包中常用頁邊距屬性存在section的以下4個屬性中:
section.top_margin
:上頁邊距
section.bottom_margin
:下頁邊距
section.left_margin
:左頁邊距
section.right_margin
:右頁邊距
頁邊距的值以厘米(cm)為單位,讓我們來看看剛才第二節的默認的頁邊距是多少
>>> print('上',doc.sections[1].top_margin.cm,'下',doc.sections[1].bottom_margin.cm,'左',doc.sections[1].left_margin.cm,'右',doc.sections[1].right_margin.cm) 上 2.54 下 2.54 左 3.175 右 3.175
註,這裡的sections[1]是第二節。
下面把頁邊距設置成我們公文常用的5678頁面距
>>> from docx.shared import Cm >>> doc.sections[1].top_margin = Cm(3.7) >>> doc.sections[1].bottom_margin = Cm(3.5) >>> doc.sections[1].left_margin = Cm(2.8) >>> doc.sections[1].right_margin = Cm(2.6)
這裡要先導入docx中定義單位的Cm,後面常用的單位還有Pt 也是這個塊導入。
另外 頁邊距屬性還有3個不常用的就是裝訂線,頁眉、頁腳邊距分別為:section.gutter,section.header_distance, section.footer_distance
,設置方法同上,不再贅述。需要說明的是裝訂線還有一個位置屬性,暫時未發現如何設置,默認為左,如果需求設置成右,可以建個模板docx文檔導入。
設置紙張方向和大小
Section中的三個屬性描述瞭頁面方向和尺寸。分別為:section.orientation, section.page_width, section.page_height
紙張大小設置單位我習慣用cm,設置同頁邊距。
這裡要特別說下orientation,即紙張方向,也是要設置的,不能說你把紙張寬度設置寬瞭,高度設置低瞭紙張就變成橫向瞭,會影響打印等。
紙張方向的值是docx.enum.section.WD_ORIENTATION中枚舉類型的2常量來設置的。分別為:
WD_ORIENTATION.LANDSCAPE
:紙張方向為橫向。
WD_ORIENTATION.PORTRAIT
:紙張方向為縱向。
先查看下:
>>> doc.sections[0].page_height.cm 27.94 >>> doc.sections[0].page_width.cm 21.59 >>> doc.sections[0].orientation 0
默認的是信紙大小,橫向
設置成我們常用的A4紙大小下:
from docx.shared import Cm from docx.enum.section import WD_ORIENTATION doc.sections[0].page_height = Cm(29.7) # 設置A4紙的高度 doc.sections[0].page_width = Cm(21) # 設置A4紙的寬 doc.sections[0].orientation = WD_ORIENTATION.PORTRAIT # 設置紙張方向為橫向,可以不設置 默認為橫向 doc.sections[1].page_height = Cm(21) # 設置A4紙的高度 doc.sections[1].page_width = Cm(29.7) # 設置A4紙的寬 doc.sections[1].orientation = WD_ORIENTATION.LANDSCAPE # 設置紙張方向為縱向
設置分欄
有些時候我們還要在某些節中分欄,給節設置分欄的語句比較固定,就是更改section的一個私有屬性。先導入docx.oxml.ns.qn,然後一句話搞定
from docx.oxml.ns import qn doc.sections[1]._sectPr.xpath('./w:cols')[0].set(qn('w:num'), '2') #把第二節設置為2欄
想設置成幾欄 把‘2’就改成幾。
總結
本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!
推薦閱讀:
- 詳解python-docx處理Word必備工具
- 使用python處理一萬份word表格簡歷操作
- Python操作word文檔的示例詳解
- 詳解用 python-docx 創建浮動圖片
- Python辦公自動化解決world文件批量轉換