Как создать отдельный файл CSV из VBA? - PullRequest
11 голосов
/ 07 декабря 2011

Мне нужно вывести некоторые результаты в виде файла .csv, который затем обрабатывается другим процессом.Чтобы получить эти результаты, у меня есть огромная рабочая тетрадь, содержащая все макросы и функции, которые мне нужны.

  1. Можно ли "создать" отдельный файл .csv из VBA?
  2. Возможно ли использовать VBA функции для записи в него вместо простого «текстового» подхода?

Спасибо:)

Ответы [ 3 ]

24 голосов
/ 07 декабря 2011

Это то, что вы хотите?

Option Explicit
Sub WriteFile()

  Dim ColNum As Integer
  Dim Line As String
  Dim LineValues() As Variant
  Dim OutputFileNum As Integer
  Dim PathName As String
  Dim RowNum As Integer
  Dim SheetValues() As Variant

  PathName = Application.ActiveWorkbook.Path
  OutputFileNum = FreeFile

  Open PathName & "\Test.csv" For Output Lock Write As #OutputFileNum

  Print #OutputFileNum, "Field1" & "," & "Field2"

  SheetValues = Sheets("Sheet1").Range("A1:H9").Value
  ReDim LineValues(1 To 8)

  For RowNum = 1 To 9
    For ColNum = 1 To 8
      LineValues(ColNum) = SheetValues(RowNum, ColNum)
    Next
    Line = Join(LineValues, ",")
    Print #OutputFileNum, Line
  Next

  Close OutputFileNum

End Sub

Не забывайте, что вам нужно будет заключать в кавычки любое поле, содержащее запятую.

9 голосов
/ 22 марта 2016

Ответ Тони обычно работает, но не обрабатывает случай, когда ваш текст содержит запятые или кавычки.Вы можете предпочесть использовать метод Workbook.SaveAs.

Вот пример, если вы хотите сохранить содержимое Sheet1 в виде отдельного файла CSV.

Sub create_csv()
    Dim FileName As String
    Dim PathName As String
    Dim ws As Worksheet

    Set ws = ActiveWorkbook.Sheets("Sheet1")
    FileName = "filename.csv"
    PathName = Application.ActiveWorkbook.Path
    ws.Copy
    ActiveWorkbook.SaveAs FileName:=PathName & "\" & FileName, _
        FileFormat:=xlCSV, CreateBackup:=False
End Sub

Представьте, что ваш Sheet1 содержит:

lorem ipsum

lore, m ips "um"

ВыходCSV-файл будет:

lorem, ipsum

"lore, m", "ips", "um" ""

1 голос
/ 07 декабря 2011

Вы можете написать макрос, подобный сохранению текущей книги (открытого файла Excel) в CSV из VBA:

ActiveWorkbook.SaveAs Filename:="C:\Book1.csv", _
    FileFormat:=xlCSVMSDOS, CreateBackup:=False
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...