Можно ли выбрать, какие конкретные элементы управления формы извлекаются из слова в Excel?
В данный момент у меня есть макрос, который отлично работает и извлекает все элементы управления формой в Excel в одну строку. Дело в том, что мне нужно разбить элементы управления на 3 разных раздела. У каждого свой лист / вкладка. Элементы управления формой - это текстовые и выпадающие списки.
Например: скажем, в форме 9 вопросов.
1-й лист / вкладка, макрос будет тянуть вопросы
1.
2.
3.
2-й лист / вкладка, макрос будет тянуть вопросы (я не против отдельного макроса)
4.
5.
6.
3-й макрос листа / вкладки будет задавать вопросы (я не против отдельного макроса)
7.
8.
9.
Текущий макрос, который отлично работает, но содержит каждый элемент управления:
Sub GetFormData()
'Note: this code requires a reference to the Word object model
Application.ScreenUpdating = False
Dim wdApp As New Word.Application, wdDoc As Word.Document, CCtrl As Word.ContentControl
Dim strFolder As String, strFile As String, WkSht As Worksheet, i As Long, j As Long
strFolder = GetFolder
If strFolder = "" Then Exit Sub
Set WkSht = ActiveSheet
i = WkSht.Cells(WkSht.Rows.Count, 1).End(xlUp).Row
strFile = Dir(strFolder & "\*.docx", vbNormal)
While strFile <> ""
i = i + 1
Set wdDoc = wdApp.Documents.Open(Filename:=strFolder & "\" & strFile, AddToRecentFiles:=False, Visible:=False)
With wdDoc
j = 0
For Each CCtrl In .ContentControls
With CCtrl
Select Case .Type
Case Is = wdContentControlCheckBox
j = j + 1
WkSht.Cells(i, j).Value = .Checked
Case wdContentControlDate, wdContentControlDropdownList, wdContentControlRichText, wdContentControlText
j = j + 1
WkSht.Cells(i, j).Value = .Range.Text
Case Else
End Select
End With
Next
.Close SaveChanges:=False
End With
strFile = Dir()
Wend
wdApp.Quit
Set wdDoc = Nothing: Set wdApp = Nothing: Set WkSht = Nothing
Application.ScreenUpdating = True
End Sub
Function GetFolder() As String
Dim oFolder As Object
GetFolder = ""
Set oFolder = CreateObject("Shell.Application").BrowseForFolder(0, "Choose a folder", 0)
If (Not oFolder Is Nothing) Then GetFolder = oFolder.Items.Item.Path
Set oFolder = Nothing
End Function
Пример того, как это выглядит. Вопросы повторяются, поэтому не обращайте на них внимания: