插入word的表格,怎么设置单元格居中对齐?
def get_table():t2 = document.add_table(rows=1, cols=4)
t2.style = 'Table Grid'
t2.autofit=True
hdr_cells = t2.rows.cells
#设置表头
hdr_cells.text = '运营指标'
hdr_cells.text = '本周受理量'
hdr_cells.text = '上周受理量'
hdr_cells.text = '本月累计 '
#导入数据
df = pandas.read_excel(file_path +"周报.xlsx",'南一', dtype=str, keep_default_na='') # 读取内容(每一行是一个列表)
for d in df.values.tolist():
for row1,row2,row3,row4 in :
row_cells = t2.add_row().cells
row_cells.text = row1,
row_cells.text = row2
row_cells.text = row3
row_cells.text = row4
我现在写成了这个样子,能够把EXCEL数据表插入到WORD中,但是每列单元格内文本默认是左对齐的。请问大佬们,怎么改成居中对齐? 要设置Word表格中单元格的居中对齐,可以使用paragraph.alignment属性来设置单元格内文本的对齐方式。以下是修改后的代码:
python
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
def get_table():
t2 = document.add_table(rows=1, cols=4)
t2.style = 'Table Grid'
t2.autofit = True
hdr_cells = t2.rows.cells
# 设置表头
hdr_cells.text = '运营指标'
hdr_cells.text = '本周受理量'
hdr_cells.text = '上周受理量'
hdr_cells.text = '本月累计'
# 导入数据
df = pandas.read_excel(file_path + "周报.xlsx", '南一', dtype=str, keep_default_na='')
# 读取内容(每一行是一个列表)
for d in df.values.tolist():
for row1, row2, row3, row4 in :
row_cells = t2.add_row().cells
row_cells.text = row1
row_cells.text = row2
row_cells.text = row3
row_cells.text = row4
# 设置单元格内文本居中对齐
for cell in row_cells:
for paragraph in cell.paragraphs:
paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER
在修改后的代码中,我们使用WD_PARAGRAPH_ALIGNMENT.CENTER来设置单元格内文本的居中对齐方式。遍历每个单元格的段落,并将其对齐方式设置为居中对齐。
希望这可以帮助到您!如果还有其他疑问,请随时向我提问。 您可以通过设置单元格的段落属性来实现单元格中的文本居中对齐。在python-docx库中,Paragraph对象有一个alignment属性,您可以使用它来设置文本的对齐方式。请参考以下代码:
from docx.enum.text import WD_ALIGN_PARAGRAPH
from docx import Document
def set_cell_vertical_alignment(cell, align="center"):
try:
tc = cell._tc
tcPr = tc.get_or_add_tcPr()
tcValign = OxmlElement('w:vAlign')
tcValign.set(qn('w:val'), align)
tcPr.append(tcValign)
return True
except:
traceback.print_exc()
return False
# 创建新的文档
document = Document()
# 创建新的表格
table = document.add_table(rows=1, cols=3)
# 设置表格中每个单元格的对齐方式
for row in table.rows:
for cell in row.cells:
# 设置单元格中文本的水平对齐方式
cell.text = '文本'
paragraph = cell.paragraphs
paragraph.alignment = WD_ALIGN_PARAGRAPH.CENTER
# 设置单元格中文本的垂直对齐方式
set_cell_vertical_alignment(cell, align="center")
# 保存文档
document.save('demo.docx')
以上代码中的 WD_ALIGN_PARAGRAPH.CENTER 是用来设置文本的水平对齐方式, set_cell_vertical_alignment(cell, align="center") 是用来设置文本的垂直对齐方式。使用这些方法,你可以对文本进行水平和垂直的居中对齐。
在上面的代码中,我们首先创建了一个新的文档和一个新的表格。然后,我们遍历了表格中的每个单元格,并设置了每个单元格中文本的对齐方式。最后,我们保存了文档。
如果你想要在你现有的代码中实现文本的居中对齐,你可以在添加文本到单元格后,设置单元格段落的对齐方式,如下所示:
for d in df.values.tolist():
for row1,row2,row3,row4 in :
row_cells = t2.add_row().cells
row_cells.text = row1
row_cells.paragraphs.alignment = WD_ALIGN_PARAGRAPH.CENTER
row_cells.text = row2
row_cells.paragraphs.alignment = WD_ALIGN_PARAGRAPH.CENTER
row_cells.text = row3
row_cells.paragraphs.alignment = WD_ALIGN_PARAGRAPH.CENTER
row_cells.text = row4
row_cells.paragraphs.alignment = WD_ALIGN_PARAGRAPH.CENTER
这样,您就可以将每个单元格中的文本设置为居中对齐了。 要将表格中的文本居中对齐,你可以通过设置单元格属性来实现。在你的代码中,你可以使用`paragraph.alignment`属性将每个单元格的对齐方式设置为居中。下面是修改后的代码示例:
from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
def get_table():
t2 = document.add_table(rows=1, cols=4)
t2.style = 'Table Grid'
t2.autofit=True
hdr_cells = t2.rows.cells
# 设置表头
hdr_cells.text = '运营指标'
hdr_cells.text = '本周受理量'
hdr_cells.text = '上周受理量'
hdr_cells.text = '本月累计'
# 导入数据
df = pandas.read_excel(file_path +"周报.xlsx",'南一', dtype=str, keep_default_na='') # 读取内容(每一行是一个列表)
for d in df.values.tolist():
for row1, row2, row3, row4 in :
row_cells = t2.add_row().cells
row_cells.text = row1
row_cells.text = row2
row_cells.text = row3
row_cells.text = row4
# 将单元格内文本居中对齐
for cell in row_cells:
for paragraph in cell.paragraphs:
paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER
这样修改后,每个单元格中的文本都会被居中对齐。 陶远航 发表于 2023-7-6 09:56
要设置Word表格中单元格的居中对齐,可以使用paragraph.alignment属性来设置单元格内文本的对齐方式。以下 ...
这样内容是可以了。但是表头还是左对齐的。再怎么调一下呀? 还要起名字呐 发表于 2023-7-6 10:06
这样内容是可以了。但是表头还是左对齐的。再怎么调一下呀?
啊,我在表头下面又加了一组for循环,解决了。非常感谢 还要起名字呐 发表于 2023-7-6 10:10
啊,我在表头下面又加了一组for循环,解决了。非常感谢
nb
页:
[1]