尽管 Excel 制表符分隔导出工作完美,但我需要尽快在所选内容上生成制表符分隔文件。
找到/编辑了下面的代码并为其分配了一个 Excel 宏快捷方式:
Sub QuoteCommaExport()
Dim DestFile As String
Dim FileNum As Integer
Dim ColumnCount As Integer
Dim RowCount As Integer
' Prompt user for destination file name.
DestFile = InputBox("Enter the destination filename" & _
Chr(10) & "(with complete path and extension):", _
"Quote-Comma Exporter", "C:\myTabFile.txt")
' Obtain next free file handle number.
FileNum = FreeFile()
' Turn error checking off.
On Error Resume Next
' Attempt to open destination file for output.
Open DestFile For Output As #FileNum
' If an error occurs report it and end.
If Err <> 0 Then
MsgBox "Cannot open filename " & DestFile
End
End If
' Turn error checking on.
On Error GoTo 0
Dim topString
For ColumnCount = 1 To Selection.Columns.Count
If ColumnCount < Selection.Columns.Count Then
topString = topString & """" & ActiveSheet.Cells(ColumnCount, 1).Text & """" & vbTab
Else
topString = topString & """" & ActiveSheet.Cells(ColumnCount, 1).Text & """"
End If
Next ColumnCount
Print #FileNum, topString
' Loop for each row in selection.
For RowCount = 1 To Selection.Rows.Count
' Loop for each column in selection.
For ColumnCount = 1 To Selection.Columns.Count
' Write current cell's text to file with quotation marks.
Print #FileNum, """" & Selection.Cells(RowCount, _
ColumnCount).Text & """";
' Check if cell is in last column.
If ColumnCount = Selection.Columns.Count Then
' If so, then write a blank line.
Print #FileNum,
Else
' Otherwise, write a comma.
' Print #FileNum, ",";
Print #FileNum, vbTab;
End If
' Start next iteration of ColumnCount loop.
Next ColumnCount
' Start next iteration of RowCount loop.
Next RowCount
' Close destination file.
Close #FileNum
End Sub