VBA - 从多个文本文件导入 n 行

VBA - import n lines from multiple text files

我有一段代码可以导入包含我需要的一些数据的多个文本文件。我想稍微更改一下 - 我希望它在到达文本文件中的第 50 行后停止读取文件并仅导入前 50 行。有什么办法可以做到这一点?我正在考虑一个逐行执行代码直到行号大于 50 的循环。我想出了一种编写这样一个循环的方法,但是它不会将行拆分为列,我需要那个。同样以我编写它的方式,它只导入 1 个文件。我有一个代码可以读取多个文件并将它们分成几列,但我无法在 50 行后结束。我为此使用了 QueryTables。也许我可以借鉴它而不是做那个循环?

这是我的 - 它显然不起作用:

Sub RT()
Dim fso As Object
Dim xlsheet As Worksheet
Dim qt As QueryTable
Dim txtfilesToOpen As Variant, txtfile As Variant
Dim rec As String
Dim i As Long
Dim txtfilnumber As Integer
Dim FileNumber
Dim txtline As String
    i = 0

Application.ScreenUpdating = False
txtfilesToOpen = Application.GetOpenFilename _
             (FileFilter:="Text Files (*.txt), *.txt", _
              MultiSelect:=True, Title:="Text Files to Open")

With ActiveSheet
    .Cells.ClearContents
    For Each txtfile In txtfilesToOpen
        importrow = 2 + .Cells(.Rows.Count, 1).End(xlUp).Row
        With CreateObject("Scripting.FileSystemObject").OpenTextFile(txtfile)
            Do While Not .AtEndOfStream
                If .line < 50 Then
                    Cells(.line, 1).Value = .ReadLine
                Else: Exit Do
                End If
            Loop
        End With
    Next txtfile

    For Each qt In .QueryTables
       qt.Delete
    Next qt

End With

Application.ScreenUpdating = True
MsgBox "Successfully imported text files!", vbInformation, "SUCCESSFUL IMPORT"

Set fso = Nothing

End Sub

有谁知道我该如何处理这个问题?我真的很陌生,但仍然很迷茫。我在这里几乎是在黑暗中刺伤。如果您能告诉我我可以做什么或使用什么功能,我将不胜感激!

您的代码导入了多个文件,但是,它总是会覆盖先前导入文件的内容。您需要将 importrow 添加到单元格地址。

当你想将文本分成几列时,你需要知道如何拆分。你有字段分隔符(制表符、分号、逗号)吗?固定长度?

以下代码将假定分号作为分隔符,将文本拆分为多个单元格。可能有点慢,但你会明白的。

Do While Not .AtEndOfStream
   If .line > 50 Then Exit Do
  
   Dim txtLine as String, tokens() as String, i as long
   txtLine = .ReadLine
   tokens = Split(txtLine, ";")
   For i = 0 to UBound(tokens)
       .Cells(importrow + .line, i+1).Value = tokens(i)
   Next i
Loop