bottom
Great ExcelTips!
         
Your e-mail address is safe!
Close Note

Tips.Net > ExcelTips Home > Files > Faster Text File Conversions

Faster Text File Conversions

Summary: When importing a text file into Excel, you have the opportunity to define the characteristics of the data being imported. If the data has quite a few fields in it, specifying the characteristics of each field can be tedious. This tip explains a couple of ways you can make faster work of this importing process. (This tip works with Microsoft Excel 97, Excel 2000, Excel 2002, and Excel 2003.)

Pat wondered how to change the default column data type from "general" to "text" for all columns of a comma-delimited text file. Changing the format of each column, especially when there are many of them, can be tedious at best.

Unfortunately, there is no way to change the default. However, the changing of the column data types can be done much more easily by applying a little of the "pick and choose" features available in most Windows programs. Follow these steps:

  1. Start to import your comma-delimited text file as you normally would.
  2. When the dialog box is displayed that allows you to change column data types, select the first column in the table.
  3. Scroll to the right in the dialog box so the last column in the table is visible.
  4. Hold down the Shift key as you click on the last column. Now all the columns should be selected.
  5. Change the data type to Text.
  6. Continue with the import, as usual.

If you prefer an even faster way of inputting the information from the comma-delimited text file, you can do so using a macro, thereby skipping the Excel import filters entirely. The following macro, entitled (appropriately enough) Import, will do the trick:

Sub Import()
    Open "d:\data.txt" For Input As #1
    R = 1
    While Not EOF(1) 'Scan file line by line
        C = 1
        Entry = ""
        Line Input #1, Buffer
        Length = Len(Buffer)
        i = 1
        While i <= Length 'split comma-delimited string into cells
            If (Mid(Buffer, i, 1)) = "," Then
                With Application.Cells(R, C)
                    .NumberFormat = "@" 'Text formatting
                    .Value = Entry
                End With
                C = C + 1
                Entry = ""
            Else
                Entry = Entry + Mid(Buffer, i, 1)
            End If
            i = i + 1
        Wend
        If Len(Entry) > 0 Then
            With Application.Cells(R, C)
                .NumberFormat = "@" 'Text formatting
                .Value = Entry
            End With
        End If
        R = R + 1
    Wend
    Close #1
End Sub

You should note that you can change the first line of the macro to represent the name of the file you are importing. You should also understand that this macro works on the simplest of comma-delimited text files. If the file was created with quote marks around each field (as is sometimes the case), then the macro will not give the desired results and would need to be changed to compensate for the quote marks. Or, as an alternative, you could simply use search for and remove the quotes after the macro is through importing the information.

Tip #2235 applies to Microsoft Excel versions: 97 | 2000 | 2002 | 2003


More Power! Expand your skills and make Excel really sing! It's all possible with macros. The best resource anywhere for macros is ExcelTips: The Macros. Check it out today!

Helpful Links

Ask an Excel Question
Make a Comment

Tips.Net Home
Vital News Home

ExcelTips FAQ
ExcelTips Premium

Learn Access Now

Beauty Tips
Bugs and Pests Tips
Car Tips
Cleaning Tips
College Tips
Cooking Tips
Excel2007 Tips
ExcelTips
Family Tips
Gardening Tips
Health Tips
Home Tips
Money Tips
Organizing Tips
Pet Tips
Word2007 Tips
WordTips

Advertise on the
ExcelTips Site

 

Great Info!

Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your e-mail address and click "Subscribe."
     
(Your e-mail address will never be shared with anyone, ever.)