MS Excel - Извлечение данных поля формы из MS WORD в EXCEL - Проблема формата даты - PullRequest
0 голосов
/ 28 апреля 2020

Я успешно использую какой-то VB, который нашел здесь и настроил в соответствии со своими потребностями " Извлечение данных из Word в Excel " для извлечения данных формы из Word в Excel (благодаря все, кто там писал) но у меня проблема с датами, где дата была введена как дд / мм / гг в форме, которую она передает в Excel как мм / дд / гг, это происходит только тогда, когда дд меньше чем 13.

Нет подтверждения данных в поле формы, поэтому оно представляется как дд.мм.гг, дд-мм-гг, дд / мм / гг, но это только дд / мм / гг, вызывающее проблема.

Очевидный ответ заключается в обновлении проверки данных форм, которая была проделана в будущем, но для текущих представлений я надеюсь, что кто-то может помочь?

Спасибо

Код

Sub GetData()


Application.ScreenUpdating = False
Dim wdApp As New Word.Application, wdDoc As Word.Document
Dim FmFld As Word.FormField, CCtrl As Word.ContentControl
Dim strFolder As String, strFile As String
Dim 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
'Disable any auto macros in the documents being processed
wdApp.WordBasic.DisableAutoMacros
strFile = Dir(strFolder & "\*.doc", vbNormal)
While strFile <> ""
 i = i + 1
 Set wdDoc = wdApp.Documents.Open(fileName:=strFolder & "\" & strFile, AddToRecentFiles:=False, Visible:=False)
 With wdDoc
   j = 0
   For Each FmFld In .FormFields
     j = j + 1
     With FmFld
       Select Case .Type
         Case Is = wdFieldFormCheckBox
           WkSht.Cells(i, j) = .CheckBox.Value
         Case Else
           If IsNumeric(FmFld.Result) Then
             If Len(FmFld.Result) > 15 Then
               WkSht.Cells(i, j) = "'" & FmFld.Result
             Else
               WkSht.Cells(i, j) = FmFld.Result
             End If
           Else
             WkSht.Cells(i, j) = FmFld.Result
           End If
       End Select
     End With
   Next
   For Each CCtrl In .ContentControls
     With CCtrl
       Select Case .Type
         Case Is = wdContentControlCheckBox
           j = j + 1
           WkSht.Cells(i, j) = .Checked
         Case wdContentControlDate, wdContentControlDropdownList, wdContentControlRichText, wdContentControlText
           j = j + 1
           If IsNumeric(.Range.Text) Then
             If Len(.Range.Text) > 15 Then
               WkSht.Cells(i, j).Value = "'" & .Range.Text
             Else
               WkSht.Cells(i, j).Value = .Range.Text
             End If
           Else
             WkSht.Cells(i, j) = .Range.Text
           End If
         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



...