Word VBA – 在表格的右端添加列

huangapple go评论126阅读模式
英文:

Word VBA - Add column to the right end of a table

问题

Edit 1:

以下是代码的翻译部分:

Sub Atest()
 
    Dim t As Table, r As Long, p As Long
    Set t = ActiveDocument.Tables(1)
    
    t.Cell(1, 1).Select                                         '选择表格的第一个单元格
    p = Selection.Information(wdMaximumNumberOfColumns)         '获取当前列数
    t.Cell(1, p).Select                                         '选择表格的第一行,最后一个单元格
    q = Selection.Information(wdMaximumNumberOfRows)            '获取当前行数
    
    For r = 1 To q
        t.Cell(r, 1).Select
        p = Selection.Information(wdMaximumNumberOfColumns)         '获取当前行的列数
        Debug.Print "r 的值为:"; r
        Debug.Print "p 的值为:"; p
        t.Cell(r, p).Select
        Selection.InsertCells (0)                                   '插入右侧单元格
        
    Next r

End Sub

Edit 2:

以下是代码的翻译部分:

Sub AddNewColumnToTable()
    
    Dim t As Table
    
    Set t = ActiveDocument.Tables(1)
    t.Select
    Selection.Columns.Add
        
End Sub

以下是代码的翻译部分:

Sub InsertNewColumnToTable()
    
    Dim t As Table
    
    Set t = ActiveDocument.Tables(1)
    t.Select
    Selection.InsertColumnsRight
        
End Sub

如果你需要更多帮助或有其他问题,请随时提问。

英文:

I have a document with nearly 1400 tables. The number of columns in each table is not always the same. Each table has a mixture of horizontally and vertically merged cells. I need to add a column to the right side of each table.

Note that I didn't write it from scratch, but I did modify it. Currently it only looks at the first table, once I get it working, I will loop it to change every table.

Edit 1:

The following error occurs at 't.Cell(r, 1).Select'

Runtime error '5941':
The requested member of the collection does not exist.

What I believe is happening is that I store the max number of rows used in 'q' and loop from the first row all the way to 'q'. The table I'm testing on has 6 maximum rows, but the first column has 1 cell as a title block and then a vertically merged cell that encompasses the remaining 5 rows.

Because 't.Cell(r, 1).Select' is using the first column, it gets to cell 3 in column 1, which doesn't exist because of the merged cells.

Any advice would be appreciated, thank you.

Sub Atest()
 
    Dim t As Table, r As Long, p As Long
    Set t = ActiveDocument.Tables(1)
    
    t.Cell(1, 1).Select                                         'select table first cell
    p = Selection.Information(wdMaximumNumberOfColumns)         'get current column count
    t.Cell(1, p).Select                                         'select table first row, last cell
    q = Selection.Information(wdMaximumNumberOfRows)            'get current row count
    
    For r = 1 To q
        t.Cell(r, 1).Select
        p = Selection.Information(wdMaximumNumberOfColumns)         'get column count of current row
        Debug.Print "the value of r is "; r
        Debug.Print "the value of p is "; p
        t.Cell(r, p).Select
        Selection.InsertCells (0)                                   'insert cell right
        
    Next r

End Sub

Edit 2:

This is the table I'm trying to add a column to. Table used for testing

Using the code below results in 2 columns being added to the beginning of the table, rather than one column at the end like I want. Table after running AddNewColumnToTable()

Sub AddNewColumnToTable()
    
    Dim t As Table
    
    Set t = ActiveDocument.Tables(1)
    t.Select
    Selection.Columns.Add
        
End Sub

Using this code results in two columns being added after the 2nd column. Table after running InsertNewColumnToTable()

Sub InsertNewColumnToTable()
    
    Dim t As Table
    
    Set t = ActiveDocument.Tables(1)
    t.Select
    Selection.InsertColumnsRight
        
End Sub

答案1

得分: 0

迄今为止,Tim的解决方案 Application.CommandBars.ExecuteMso "TableColumnsInsertRight" 似乎是最佳和最稳定的,速度也很快。

请尝试我的代码:

  • 无需集合,减少循环次数:
Sub Word_VBA_Add_column_to_the_right_end_of_a_table()
    Dim tb As Word.Table, c As Word.Cell, ur As Word.UndoRecord, d As Word.Document, r As Byte
    Dim newColumnWidth As Single
    Set ur = Word.Application.UndoRecord
    ur.StartCustomRecord "Word_VBA_Add_column_to_the_right_end_of_a_table"
    Set d = ActiveDocument
    Word.Application.ScreenUpdating = False
    For Each tb In d.Tables
        For Each c In tb.Range.Cells
            If r = 0 Then
                r = c.RowIndex
            Else
                If c.RowIndex > r Then
                    If newColumnWidth = 0 Then newColumnWidth = c.Previous.Width
                    c.Previous.Range.Cells.Add.Width = newColumnWidth
                    r = c.RowIndex
                End If
                    
            End If
        Next c
        tb.Range.Cells(tb.Range.Cells.Count).Range.Cells.Add.Width = newColumnWidth
        r = 0: newColumnWidth = 0
    Next tb
    ur.EndCustomRecord
    Word.Application.ScreenUpdating = True
End Sub
Sub Word_VBA_Add_column_to_the_right_end_of_a_table()
    Dim tb As Word.Table, c As Word.Cell, ur As Word.UndoRecord, d As Word.Document, r As Byte, cln As New VBA.Collection
    Dim newColumnWidth As Single
    Set ur = Word.Application.UndoRecord
    ur.StartCustomRecord "Word_VBA_Add_column_to_the_right_end_of_a_table"
    Set d = ActiveDocument
    Word.Application.ScreenUpdating = False
    For Each tb In d.Tables
        For Each c In tb.Range.Cells
            If r = 0 Then
                r = c.RowIndex
            Else
                If c.RowIndex > r Then
                    cln.Add c.Previous
                    r = c.RowIndex
                End If
                    
            End If
        Next c
        ' If newColumnWidth = 0 Then
        newColumnWidth = cln(1).Width ' 设置新列的宽度值在这里
        ' End If

        For Each c In cln
        ' c.Select ' 仅用于测试
            c.Range.Cells.Add.Width = newColumnWidth
        Next c
        tb.Range.Cells(tb.Range.Cells.Count).Range.Cells.Add.Width = newColumnWidth
        r = 0: Set cln = Nothing
    Next tb
    ur.EndCustomRecord
    Word.Application.ScreenUpdating = True
End Sub

这将在现有单元格的右侧插入一个新单元格。
然而,我的先前解决方案存在严重问题。这是因为插入的单元格实际上是在现有单元格的左侧插入的,而不是在表格的最右侧,这不是表格的最右侧。
所以我必须将内容从新单元格的右侧移到新单元格上,问题似乎已经解决,如下所示:

Sub Word_VBA_Add_column_to_the_right_end_of_a_table()
    Dim tb As Word.Table, c As Word.cell, ur As Word.UndoRecord, d As Word.Document, r As Byte, cln As New VBA.Collection
    Dim newCell As Word.cell
    Dim newColumnWidth As Single
    Set ur = Word.Application.UndoRecord
    ur.StartCustomRecord "Word_VBA_Add_column_to_the_right_end_of_a_table"
    Set d = ActiveDocument
    Word.Application.ScreenUpdating = False
    For Each tb In d.Tables
        For Each c In tb.Range.Cells
            If r = 0 Then
                r = c.RowIndex
            Else
                If c.RowIndex > r Then
                    cln.Add c.Previous
                    r = c.RowIndex
                End If
                    
            End If
        Next c
        For Each c In cln
            If newColumnWidth = 0 Then
                newColumnWidth = c.Width
            End If
            Set newCell = tb.Range.Cells.Add(c)
            newCell.Next.Width = newColumnWidth
            newCell.Next.Range.Cut: newCell.Range.Paste
            ' newCell.Range.FormattedText = newCell.Next.Range.FormattedText
            ' c.Range.Delete
        Next c
        Set newCell = tb.Range.Cells.Add(tb.Range.Cells(tb.Range.Cells.Count))
        newCell.Next.Width = newColumnWidth
        newCell.Next.Range.Cut: newCell.Range.Paste
        r = 0: Set cln = Nothing
    Next tb
    ur.EndCustomRecord
    Word.Application.ScreenUpdating = True
End Sub

只需在每行的最后一个单元格之后插入/添加一个新单元格。

之前:
Word VBA – 在表格的右端添加列
之后:
Word VBA – 在表格的右端添加列

英文:

So far, Tim's solution Application.CommandBars.ExecuteMso "TableColumnsInsertRight" seems to be the best and most stable, fast.

Plz try my code to see:

  • Without Collection, Save a loop:
Sub Word_VBA_Add_column_to_the_right_end_of_a_table()
    Dim tb As Word.Table, c As Word.Cell, ur As Word.UndoRecord, d As Word.Document, r As Byte
    Dim newColumnWidth As Single
    Set ur = Word.Application.UndoRecord
    ur.StartCustomRecord "Word_VBA_Add_column_to_the_right_end_of_a_table"
    Set d = ActiveDocument
    Word.Application.ScreenUpdating = False
    For Each tb In d.Tables
        For Each c In tb.Range.Cells
            If r = 0 Then
                r = c.RowIndex
            Else
                If c.RowIndex > r Then
                    If newColumnWidth = 0 Then newColumnWidth = c.Previous.Width
                    c.Previous.Range.Cells.Add.Width = newColumnWidth
                    r = c.RowIndex
                End If
                    
            End If
        Next c
        tb.Range.Cells(tb.Range.Cells.Count).Range.Cells.Add.Width = newColumnWidth
        r = 0: newColumnWidth = 0
    Next tb
    ur.EndCustomRecord
    Word.Application.ScreenUpdating = True
End Sub

Sub Word_VBA_Add_column_to_the_right_end_of_a_table()
    Dim tb As Word.Table, c As Word.Cell, ur As Word.UndoRecord, d As Word.Document, r As Byte, cln As New VBA.Collection
    Dim newColumnWidth As Single
    Set ur = Word.Application.UndoRecord
    ur.StartCustomRecord "Word_VBA_Add_column_to_the_right_end_of_a_table"
    Set d = ActiveDocument
    Word.Application.ScreenUpdating = False
    For Each tb In d.Tables
        For Each c In tb.Range.Cells
            If r = 0 Then
                r = c.RowIndex
            Else
                If c.RowIndex > r Then
                    cln.Add c.Previous
                    r = c.RowIndex
                End If
                    
            End If
        Next c
'        If newColumnWidth = 0 Then
            newColumnWidth = cln(1).Width ' set the new column's width value here
'        End If

        For Each c In cln
'            c.Select'just for test
            c.Range.Cells.Add.Width = newColumnWidth
        Next c
        tb.Range.Cells(tb.Range.Cells.Count).Range.Cells.Add.Width = newColumnWidth
        r = 0: Set cln = Nothing
    Next tb
    ur.EndCustomRecord
    Word.Application.ScreenUpdating = True
End Sub

This will insert a new cell to the right of the existing cell.
However, My previous solution had serious problems. This is because the inserted cells are actually inserted to the left of the existing cells, not to the right, which is not the far right side of the table.
So I have to move the content from the right of the new cell to the new one, and the problem above seems to be solved like this:

Sub Word_VBA_Add_column_to_the_right_end_of_a_table()
    Dim tb As Word.Table, c As Word.cell, ur As Word.UndoRecord, d As Word.Document, r As Byte, cln As New VBA.Collection
    Dim newCell As Word.cell
    Dim newColumnWidth As Single
    Set ur = Word.Application.UndoRecord
    ur.StartCustomRecord "Word_VBA_Add_column_to_the_right_end_of_a_table"
    Set d = ActiveDocument
    Word.Application.ScreenUpdating = False
    For Each tb In d.Tables
        For Each c In tb.Range.Cells
            If r = 0 Then
                r = c.RowIndex
            Else
                If c.RowIndex > r Then
                    cln.Add c.Previous
                    r = c.RowIndex
                End If
                    
            End If
        Next c
        For Each c In cln
            If newColumnWidth = 0 Then
                newColumnWidth = c.Width
            End If
            Set newCell = tb.Range.Cells.Add(c)
            newCell.Next.Width = newColumnWidth
            newCell.Next.Range.Cut: newCell.Range.Paste
'            newCell.Range.FormattedText = newCell.Next.Range.FormattedText
            'c.Range.Delete
        Next c
        Set newCell = tb.Range.Cells.Add(tb.Range.Cells(tb.Range.Cells.Count))
        newCell.Next.Width = newColumnWidth
        newCell.Next.Range.Cut: newCell.Range.Paste
        r = 0: Set cln = Nothing
    Next tb
    ur.EndCustomRecord
    Word.Application.ScreenUpdating = True
End Sub

Just insert/add a new cell after the last cell of each row.

Before:
Word VBA – 在表格的右端添加列
After:
Word VBA – 在表格的右端添加列

答案2

得分: -1

这对我有效:

子过程 Atest()

    Dim t As 表格
    设置 t = 活动文档.表格(1)
    t.列.添加
    t.列.自适应

结束子过程
英文:

This works for me:

Sub Atest()
 
    Dim t As Table
    Set t = ActiveDocument.Tables(1)
    t.Columns.Add
    t.Columns.Autofit



End Sub

</details>



huangapple
  • 本文由 发表于 2023年6月30日 03:17:53
  • 转载请务必保留本文链接:https://go.coder-hub.com/76584030.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定