python-docx下载_python-docx

from docx importDocumentfrom docx.shared importRGBColor,Inches,Pt,Lengthfrom docx.enum.text import WD_ALIGN_PARAGRAPH, WD_TAB_ALIGNMENT, WD_TAB_LEADER #会有红色下划线报异常,不过可以正常使用

from docx.oxml.ns importqnfrom docx.oxml importOxmlElement

document=Document()#===============================段落操作================================

document.add_heading('This is my title', 0) #添加标题,但是这个标题下面会有一个横线

#设置字体

document.styles['Normal'].font.name = u'黑体' #可换成word里面任意字体

p =document.add_paragraph()#设置文字对齐方式

p.paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER #段落文字居中设置#print(p.paragraph_format.alignment) # 打印对齐方式

#设置段落的颜色及字体大小

run = p.add_run(u'我添加的段落文字')

run.font.color.rgb= RGBColor(54, 95, 145) #颜色设置,这里是用RGB颜色

run.font.size = Pt(36) #字体大小设置,和word里面的字号相对应

#==========缩进 默认左侧=========

paragraph =document.add_paragraph()

paragraph.add_run('Indentation is specified using a Length value, such as Inches, Pt, or Cm. Negative values are valid and cause the paragraph to overlap the margin by the specified amount. A value of None indicates the indentation value is inherited from the style hierarchy. Assigning None to an indentation property removes any directly-applied indentation setting and restores inheritance from the style hierarchy:')

paragraph_format=paragraph.paragraph_format#print(paragraph_format.left_indent)#paragraph_format.left_indent = Inches(0.5) # 设置为0.5 单位是cm,默认数字为正,向右缩进,为负,则向左移#print(paragraph_format.left_indent)#print(paragraph_format.left_indent.inches)

#右侧缩进#print(paragraph_format.right_indent)

paragraph_format.right_indent = Pt(24)#print(paragraph_format.right_indent)#print(paragraph_format.right_indent.pt) # 注意:此时是小写

#首行缩进#print(paragraph_format.first_line_indent)

paragraph_format.first_line_indent = Inches(0.25)#print(paragraph_format.first_line_indent)#print(paragraph_format.first_line_indent.inches)

#==========制表符==========

"""制表符停止确定段落文本中制表符的呈现。

特别是,它指定了选项卡字符后面的文本将

开始的位置,它将如何与该位置对齐。"""tab_stops=paragraph_format.tab_stops

tab_stop= tab_stops.add_tab_stop(Inches(1.5))#print(tab_stop.position)#print(tab_stop.position.inches)

#默认左对齐,但可以通过提供WD_TAB对准枚举领导字符默认为空格,但可以通过提供WD_TAB领导枚举

tab_stop = tab_stops.add_tab_stop(Inches(1.5), WD_TAB_ALIGNMENT.RIGHT, WD_TAB_LEADER.DOTS) #leader为前导符#print("alignment:",tab_stop.alignment,',leader:',tab_stop.leader)

#==========段落间距==========#print(paragraph_format.space_before,paragraph_format.space_after)

paragraph_format.space_before = Pt(18) #单位:磅#print(paragraph_format.space_before.pt)

paragraph_format.space_after = Pt(12)#print(paragraph_format.space_after.pt)

#==========行距==========#print(paragraph_format.line_spacing)#print(paragraph_format.line_spacing_rule)

paragraph_format.line_spacing = Pt(18) #固定值18磅#print(paragraph_format.line_spacing)#print(paragraph_format.line_spacing_rule)#paragraph_format.line_spacing = 1.75 # 1.75倍行间距#print(paragraph_format.line_spacing)#print(paragraph_format.line_spacing_rule)

#==========分页==========

"""keep_together导致整个段落出现在同一页上,如果否则会在两页之间中断,则在段落之前发出一个分页。

keep_with_next将段落保存在与下一段相同的页面上。例如,这可以用于将节标题保持在与节的第一段相同的页面上。

page_break_before使段落放置在新页的顶部。这可以在章节标题中使用,以确保章节从新页面开始。

widow_control断开一页,以避免将段落的第一行或最后一行与段落的其余部分放在单独的页面上。"""

#print(paragraph_format.keep_together)

paragraph_format.keep_with_next =True#print(paragraph_format.keep_with_next)

paragraph_format.page_break_before =False#print(paragraph_format.page_break_before)

#===============================添加图片================================

pic = document.add_picture('1.jpg', width=Inches(1.5)) #图片和python文件不在同一个文件夹下面的时候,要补全文件地址#图片默认左对齐,要使图片居中对齐还需要创键一个新的对象

last_paragraph = document.paragraphs[-1] #段落属性,在这里代表每一行,一共三行,-1为最后一行

last_paragraph.alignment = WD_ALIGN_PARAGRAPH.CENTER #图片居中设置

#===============================添加表格=================================

rows = 3cols= 3table= document.add_table(rows=rows, cols=cols, style="Table Grid") #添加2行3列的表格

"""表格的style有很多种,默认情况下表格是没有边框的,

Table Grid格式是普通的黑色边框表格,更多表格样式

可以百度。但是,我们很多时候希望对表格进行更为漂

亮的修改,比如自定义表格某一列的宽度,表格的高度。"""

#设置表格宽度#table.autofit = False # 关闭表格的自适应宽度,其实与下面两条语句共同执行的话,这条语句可以省略#col = table.columns[0] # 获取表格第1列#col.width = Inches(3) # 设置表格第1列宽度为Inches(5) 默认情况下表格是自动适应文档宽度

#设置表格高度

for i in range(rows): #遍历表格的所有行

tr = table.rows[i]._tr #获取表格的每一行

trPr = tr.get_or_add_trPr() #获取或添加表行属性

trHeight = OxmlElement('w:trHeight') #获取高度属性

trHeight.set(qn('w:val'), "450") #设置高度

trPr.append(trHeight) #给表格添加高度属性,表格的每一行进行高度设置,450这个值可以任意修改

#向表格中添加文字

arr = [u'序号', u'类型', u'详情描述']

arr2= ['1', 'python', '列表']

arr3= ['2', 'java', '数组']#heading_cells = table.rows[0].cells # 将表格的第一行设置为表头#row2 = table.rows[1].cells#for i in range(cols): # cols为表格的列数#

#

#

## 表头#p = heading_cells[i].paragraphs[0] # 利用段落功能添加文字#run = p.add_run(arr[i]) # 把表头放在一个数组里面的,这样方便赋值#p.paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER # 居中设置,默认是左对齐#

## 内容第一行#r2 = row2[i].paragraphs[0]#r2.add_run(arr2[i])#r2.paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER # 居中设置,默认是左对齐

#封装成函数

definsert_data(num, cols, list):""":param num: 表格的第几行

:param cols: 表格列数

:param list: 数据

:return:"""row= table.rows[num - 1].cells #获取到表格的某一行

for i in range(cols): #遍历表格列数

r =row[i].paragraphs[0]

r.add_run(list[i])

r.paragraph_format.alignment= WD_ALIGN_PARAGRAPH.CENTER #居中设置,默认是左对齐

insert_data(1, cols, arr)

insert_data(2, cols, arr2)

insert_data(3, cols, arr3)#下面两个不推荐使用,这样会造成表格格式的混乱#直接给表中的某一个单元格赋值#table.cell(1, 1).text = 'c' # 在表格的i行j列设置文字,默认文字在表格中是左对齐#table.cell(1, 2).text = '数组(难)'

#在表格最下方添加行#table.add_row()

document.save('test.docx')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python docx 是一个用于操作 Microsoft Word 文档的 Python 库。它提供了简单而强大的 API,可以创建、修改和查询 Word 文档。 使用 Python docx,我们可以通过几行代码来创建一个新的 Word 文档,并定义段落、章节、表格、图片等。我们可以将文本、样式和格式应用于不同的段落和文本部分,并且可以插入超链接、页眉页脚以及其他文档元素。 Python docx 还提供了一些高级功能,比如可以合并多个文档、替换文本、提取文本和元数据等。我们可以利用这些功能来进行自动化生成报告、批量处理文档或者进行文档内容的提取和分析。 CSDN(中国软件开发协会)是一个非常知名的技术社区和学习平台。在 CSDN 上,你可以找到大量关于 Python docx 的教程、示例代码和问题解答,这些资源可以帮助你入门和深入理解 Python docx 的使用。 通过 CSDN,你可以学习如何使用 Python docx 来创建、修改和查询 Word 文档。你还可以了解到一些实际应用案例,例如如何利用 Python docx 生成报告、处理合同文档或者进行文档内容的自动化提取和分析。 总之,Python docx 是一个方便而强大的库,可以帮助我们在 Python 中操作 Word 文档。CSDN 是一个资源丰富的学习平台,可以为我们提供关于 Python docx 的学习资料和交流平台。使用这两个资源,我们可以在 Python 中轻松地处理和操作 Word 文档。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值