テキストファイルに書き込む

テキストファイルに書き込む

Sub テキストファイルに書き込む()
Dim myCon As New ADODB.Connection, myRS As New ADODB.Recordset
Dim myExcelFile As String, myTbl As String, myTxtFile As String

'データのあるExcelファイル
myExcelFile = ThisWorkbook.Path & "\xls\DataBook.xls"
'書き出すデータ
myTbl = "select * from [伝票一覧$] where 担当者 = '増田';"
'テキストファイル名
myTxtFile = ThisWorkbook.Path & "\txt\増田担当一覧.csv"

'エクセルに接続
With myCon
  .Provider = "Microsoft.Jet.OLEDB.4.0"
  .Properties("Extended Properties") = "Excel 8.0"
  .Open myExcelFile
End With

'レコードセットオブジェクトにテキストファイルの内容を格納
myRS.Open myTbl, myCon

'テキストファイルに書き出し
Open myTxtFile For Output As #1
  Print #1, myRS.GetString(adClipString, , ",", vbCrLf)
Close #1

myRS.Close: Set myRS = Nothing
myCon.Close: Set myCon = Nothing

End Sub

GetStringメソッドを使用して文字列として取得し、テキストファイルに書き出す。
引数を次のように指定することでカンマ区切り以外にも対応することができる。

RecordsetをOpenする際は、テーブル名を指定したり、SQLステートメントを使用できる。

このコードだけでは、フィールド見出しを書き出すことはできない。

元となるエクセルのデータ

実行結果