鱼C论坛

 找回密码
 立即注册
查看: 2889|回复: 6

[已解决]插入word的表格,怎么设置单元格居中对齐?

[复制链接]
发表于 2023-7-6 09:56:31 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
def get_table():
    t2 = document.add_table(rows=1, cols=4)   
    t2.style = 'Table Grid'
    t2.autofit=True      
    hdr_cells = t2.rows[0].cells
   
   #设置表头
    hdr_cells[0].text = '运营指标'
    hdr_cells[1].text = '本周受理量'
    hdr_cells[2].text = '上周受理量'
    hdr_cells[3].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 [d]:  
            row_cells = t2.add_row().cells           
            row_cells[0].text = row1,
            row_cells[1].text = row2
            row_cells[2].text = row3
            row_cells[3].text = row4

我现在写成了这个样子,能够把EXCEL数据表插入到WORD中,但是每列单元格内文本默认是左对齐的。请问大佬们,怎么改成居中对齐?
最佳答案
2023-7-6 09:56:46
要设置Word表格中单元格的居中对齐,可以使用paragraph.alignment属性来设置单元格内文本的对齐方式。以下是修改后的代码:
  1. python
  2. from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
  3. def get_table():
  4.     t2 = document.add_table(rows=1, cols=4)
  5.     t2.style = 'Table Grid'
  6.     t2.autofit = True
  7.     hdr_cells = t2.rows[0].cells
  8.    
  9.     # 设置表头
  10.     hdr_cells[0].text = '运营指标'
  11.     hdr_cells[1].text = '本周受理量'
  12.     hdr_cells[2].text = '上周受理量'
  13.     hdr_cells[3].text = '本月累计'
  14.    
  15.     # 导入数据
  16.     df = pandas.read_excel(file_path + "周报.xlsx", '南一', dtype=str, keep_default_na='')
  17.    
  18.     # 读取内容(每一行是一个列表)
  19.     for d in df.values.tolist():
  20.         for row1, row2, row3, row4 in [d]:
  21.             row_cells = t2.add_row().cells
  22.             row_cells[0].text = row1
  23.             row_cells[1].text = row2
  24.             row_cells[2].text = row3
  25.             row_cells[3].text = row4
  26.             
  27.             # 设置单元格内文本居中对齐
  28.             for cell in row_cells:
  29.                 for paragraph in cell.paragraphs:
  30.                     paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER
复制代码

在修改后的代码中,我们使用WD_PARAGRAPH_ALIGNMENT.CENTER来设置单元格内文本的居中对齐方式。遍历每个单元格的段落,并将其对齐方式设置为居中对齐。

希望这可以帮助到您!如果还有其他疑问,请随时向我提问。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-7-6 09:56:46 | 显示全部楼层    本楼为最佳答案   
要设置Word表格中单元格的居中对齐,可以使用paragraph.alignment属性来设置单元格内文本的对齐方式。以下是修改后的代码:
  1. python
  2. from docx.enum.text import WD_PARAGRAPH_ALIGNMENT
  3. def get_table():
  4.     t2 = document.add_table(rows=1, cols=4)
  5.     t2.style = 'Table Grid'
  6.     t2.autofit = True
  7.     hdr_cells = t2.rows[0].cells
  8.    
  9.     # 设置表头
  10.     hdr_cells[0].text = '运营指标'
  11.     hdr_cells[1].text = '本周受理量'
  12.     hdr_cells[2].text = '上周受理量'
  13.     hdr_cells[3].text = '本月累计'
  14.    
  15.     # 导入数据
  16.     df = pandas.read_excel(file_path + "周报.xlsx", '南一', dtype=str, keep_default_na='')
  17.    
  18.     # 读取内容(每一行是一个列表)
  19.     for d in df.values.tolist():
  20.         for row1, row2, row3, row4 in [d]:
  21.             row_cells = t2.add_row().cells
  22.             row_cells[0].text = row1
  23.             row_cells[1].text = row2
  24.             row_cells[2].text = row3
  25.             row_cells[3].text = row4
  26.             
  27.             # 设置单元格内文本居中对齐
  28.             for cell in row_cells:
  29.                 for paragraph in cell.paragraphs:
  30.                     paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER
复制代码

在修改后的代码中,我们使用WD_PARAGRAPH_ALIGNMENT.CENTER来设置单元格内文本的居中对齐方式。遍历每个单元格的段落,并将其对齐方式设置为居中对齐。

希望这可以帮助到您!如果还有其他疑问,请随时向我提问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-6 09:58:04 | 显示全部楼层
您可以通过设置单元格的段落属性来实现单元格中的文本居中对齐。在python-docx库中,Paragraph对象有一个alignment属性,您可以使用它来设置文本的对齐方式。请参考以下代码:

  1. from docx.enum.text import WD_ALIGN_PARAGRAPH
  2. from docx import Document

  3. def set_cell_vertical_alignment(cell, align="center"):
  4.     try:
  5.         tc = cell._tc
  6.         tcPr = tc.get_or_add_tcPr()
  7.         tcValign = OxmlElement('w:vAlign')
  8.         tcValign.set(qn('w:val'), align)
  9.         tcPr.append(tcValign)
  10.         return True
  11.     except:
  12.         traceback.print_exc()
  13.         return False

  14. # 创建新的文档
  15. document = Document()

  16. # 创建新的表格
  17. table = document.add_table(rows=1, cols=3)

  18. # 设置表格中每个单元格的对齐方式
  19. for row in table.rows:
  20.     for cell in row.cells:
  21.         # 设置单元格中文本的水平对齐方式
  22.         cell.text = '文本'
  23.         paragraph = cell.paragraphs[0]
  24.         paragraph.alignment = WD_ALIGN_PARAGRAPH.CENTER
  25.         
  26.         # 设置单元格中文本的垂直对齐方式
  27.         set_cell_vertical_alignment(cell, align="center")

  28. # 保存文档
  29. document.save('demo.docx')
复制代码


以上代码中的 WD_ALIGN_PARAGRAPH.CENTER 是用来设置文本的水平对齐方式, set_cell_vertical_alignment(cell, align="center") 是用来设置文本的垂直对齐方式。使用这些方法,你可以对文本进行水平和垂直的居中对齐。

在上面的代码中,我们首先创建了一个新的文档和一个新的表格。然后,我们遍历了表格中的每个单元格,并设置了每个单元格中文本的对齐方式。最后,我们保存了文档。

如果你想要在你现有的代码中实现文本的居中对齐,你可以在添加文本到单元格后,设置单元格段落的对齐方式,如下所示:

  1. for d in df.values.tolist():
  2.     for row1,row2,row3,row4 in [d]:  
  3.         row_cells = t2.add_row().cells           
  4.         row_cells[0].text = row1
  5.         row_cells[0].paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER
  6.         row_cells[1].text = row2
  7.         row_cells[1].paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER
  8.         row_cells[2].text = row3
  9.         row_cells[2].paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER
  10.         row_cells[3].text = row4
  11.         row_cells[3].paragraphs[0].alignment = WD_ALIGN_PARAGRAPH.CENTER
复制代码

这样,您就可以将每个单元格中的文本设置为居中对齐了。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-6 10:05:02 | 显示全部楼层
要将表格中的文本居中对齐,你可以通过设置单元格属性来实现。在你的代码中,你可以使用`paragraph.alignment`属性将每个单元格的对齐方式设置为居中。下面是修改后的代码示例:

  1. from docx.enum.text import WD_PARAGRAPH_ALIGNMENT

  2. def get_table():
  3.     t2 = document.add_table(rows=1, cols=4)   
  4.     t2.style = 'Table Grid'
  5.     t2.autofit=True      
  6.     hdr_cells = t2.rows[0].cells
  7.    
  8.     # 设置表头
  9.     hdr_cells[0].text = '运营指标'
  10.     hdr_cells[1].text = '本周受理量'
  11.     hdr_cells[2].text = '上周受理量'
  12.     hdr_cells[3].text = '本月累计'
  13.    
  14.     # 导入数据
  15.     df = pandas.read_excel(file_path +"周报.xlsx",'南一', dtype=str, keep_default_na='')      # 读取内容(每一行是一个列表)
  16.     for d in df.values.tolist():
  17.         for row1, row2, row3, row4 in [d]:  
  18.             row_cells = t2.add_row().cells           
  19.             row_cells[0].text = row1
  20.             row_cells[1].text = row2
  21.             row_cells[2].text = row3
  22.             row_cells[3].text = row4
  23.             
  24.             # 将单元格内文本居中对齐
  25.             for cell in row_cells:
  26.                 for paragraph in cell.paragraphs:
  27.                     paragraph.alignment = WD_PARAGRAPH_ALIGNMENT.CENTER
复制代码


这样修改后,每个单元格中的文本都会被居中对齐。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-6 10:06:34 | 显示全部楼层
陶远航 发表于 2023-7-6 09:56
要设置Word表格中单元格的居中对齐,可以使用paragraph.alignment属性来设置单元格内文本的对齐方式。以下 ...

这样内容是可以了。但是表头还是左对齐的。再怎么调一下呀?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-7-6 10:10:33 | 显示全部楼层
还要起名字呐 发表于 2023-7-6 10:06
这样内容是可以了。但是表头还是左对齐的。再怎么调一下呀?

啊,我在表头下面又加了一组for循环,解决了。非常感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-7-6 10:21:46 | 显示全部楼层
还要起名字呐 发表于 2023-7-6 10:10
啊,我在表头下面又加了一组for循环,解决了。非常感谢


nb
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-23 12:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表