C# 操作word表格合并单元格

C# 操作word表格

遇到合并单元格的时候,假设表格是3行6列

newTable.Cell(1, 1).Merge(newTable.Cell(1, 3));//合并第1行第1列到横向单元格合并,使用如下语句

newTable.Cell(1, 3).Merge(newTable.Cell(1, 4));
newTable.Cell(2, 4).Merge(newTable.Cell(2, 5));

最后表格如下图


可以看到,横向合并单元格的时候,列号会往右移动。

但是如果是竖向合并单元格的话,就不是这样了。

还是这个表,如果想达到下面这个效果的话


使用下面的语句就会报错

newTable.Cell(2, 1).Merge(newTable.Cell(3, 1));
newTable.Cell(3, 1).Merge(newTable.Cell(5, 1));//这句会报错

出错提示:对 COM 组件的调用返回了错误 HRESULT E_FAIL

究其原因在于,竖向合并单元格的时候,单元格的名称不会改变。如下图


之前的单元格Cell(4, 1)还存在。
正确的代码应该是这样:
 newTable.Cell(2, 1).Merge(newTable.Cell(3, 1));
 newTable.Cell(4, 1).Merge(newTable.Cell(6, 1));
具体原因可以看这个文章:https://blog.csdn.net/p656456564545/article/details/49123043 点击打开链接

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值