Excel.Tips.Net ExcelTips (Menu Interface)

Handling Leading Zeros in CSV Files

Please Note: This article is written for users of the following Microsoft Excel versions: 97, 2000, 2002, and 2003. If you are using a later version (Excel 2007 or later), this tip may not work for you. For a version of this tip written specifically for later versions of Excel, click here: Handling Leading Zeros in CSV Files.

John wrote concerning a problem with handling leading zeros in CSV files. He creates CSV files destined for import into an accounting program, but has problems with the CSV files if he needs to first reload the CSV into Excel to correct any mistakes in the file.

Actually, there are two things that need to be checked here. First, is Excel putting the leading zeros in the CSV file it initially creates? Second, is it maintaining the zeros in the CSV file when you reload it and then resave it? These are two separate issues.

You can check the first issue easily enough. All you need to do is rename the CSV file so it has a TXT extension, then you can load it into a text editor, such as Notepad. There you can examine the actual CSV file, as created by Excel, to make sure that everything is in the format you expect. If it is not—for instance, there are no leading zeros where you need them—then you need to be concerned with how Excel is creating the CSV file in the first place.

You need to check whether there are leading zeros in the original Excel information. If there are, and they are displayed, then you need to make sure that the column in which the data is contained is formatted as Text in the Number tab of the Format Cells dialog box. If they are not, then you need to format the cells using a Custom number format that displays the zeros. In both of these cases, the leading zeros will be included in the CSV file created by Excel.

This brings us to the second issue. When you load a CSV file into Excel, it tries to determine the format of the data being loaded. You probably noticed when you loaded your CSV file in Notepad that even though Excel includes leading zeros in the output file, there are no quotes around the field itself. This means that Excel automatically recognizes the field as a number when importing it. By default, then, the number is displayed using one of the number fields, thereby expunging any leading zeros in what Excel displays.

The way around this problem should be fairly obvious based on information earlier in this tip—somehow you need to get Excel to recognize the incoming information as text so that it treats the leading zeros as significant. The quickest way to do this is to follow these steps, prior to loading the CSV file:

  1. Make sure the CSV file is renamed so it has a TXT extension. You must perform this step, or the rest of the steps will not work because Excel won't start the Text Import Wizard in step 5.
  2. Within Excel, click on the Open tool on the toolbar. Excel displays the Open dialog box. (To display this dialog box in Excel 2007, click the Office button and then click on Open.)
  3. Using the Files of Type drop-down list at the bottom of the dialog box, indicate that you want to open Text Files (*.prn; *.txt; *.csv).
  4. Select the file you renamed in step 1.
  5. Click on Open. Excel starts the Text Import Wizard, displaying the Step 1 of 3 dialog box. (See Figure 1.)
  6. Figure 1. The Text Import Wizard.

  7. Make sure the Delimited choice is selected, then click on Next. Excel displays the Step 2 of 3 dialog box.
  8. Make sure Comma is selected as a delimiter, then click on Next. Excel displays the Step 3 of 3 dialog box. The interesting thing is that the data in your TXT file should be displayed at the bottom of the dialog box, including any leading zeros in your fields.
  9. At the bottom of the dialog box, click on the field that has leading zeros. The entire column should now be selected.
  10. In the Column Data Format area, make sure the Text radio button is selected.
  11. Repeat steps 8 and 9 for any other fields that have leading zeros.
  12. Click on Finish. Your file is imported, with leading zeros still intact.

Now you can do your work in Excel, as desired, and again save your data in CSV format. (You will, however, need to use Save As rather than simply using Save.) The leading zeros will be included in the data that is saved.

ExcelTips is your source for cost-effective Microsoft Excel training. This tip (2588) applies to Microsoft Excel 97, 2000, 2002, and 2003. You can find a version of this tip for the ribbon interface of Excel (Excel 2007 and later) here: Handling Leading Zeros in CSV Files.

Related Tips:

Save Time and Supercharge Excel! Automate virtually any routine task and save yourself hours, days, maybe even weeks. Then, learn how to make Excel do things you thought were simply impossible! Mastering advanced Excel macros has never been easier. Check out Excel 2010 VBA and Macros today!


Leave your own comment:

  Notify me about new comments ONLY FOR THIS TIP
Notify me about new comments ANYWHERE ON THIS SITE
Hide my email address
*What is 5+3 (To prevent automated submissions and spam.)
           Commenting Terms

Comments for this tip:

B    15 Jul 2015, 00:13
I followed everything, but when I saved it to csv format and open it again, the 0 disappears. Help! Thanks!
Héjja Huba    29 Apr 2015, 01:28
Thanks for the tutorial! You saved my day!
Greg    14 Apr 2015, 09:21
Pete Wilson ... Gold star! Exactly the solution I was after. No need to mess about in Excel. It just works.
SubbaRao    02 Apr 2015, 22:42
The above tip helped a lot. Because In my case we are preparing data and sharing to client. so, we can add prefix and suffix as said by Wilson and solved the issue. Thanks.
Charlie    04 Feb 2015, 17:59
This solution works to open a CSV file and have it formatted correctly but is there a way to maintain this after save? I have an AutoCAD program that pulls information from only a CSV file. however, once I save and then use autoCAD to import, the CSV sends that info as leading zero and instead of 00 in my drawing, I get 0. Or instead of 02-27-15 for a date, I get 02/27/2015. Can I just tell excel to stop changing my content?? Thanks
justinhimt    12 Nov 2014, 02:41
Try this...

    Excel.Range formatRange;
    formatRange = xlWorkSheet.get_Range("a1", "b1");
    formatRange.NumberFormat = "@";
    xlWorkSheet.Cells[1, 1] = "098";

Source :


Donna    21 Oct 2014, 19:09
Hi All,

Had this issue recently with trying to upload NDCs (National Drug Codes) with leading zeros. I opened the .csv file into OpenOffice and formatted the NDC column to be text as I opened the file. I formatted the NDC column again as follows once the file was open: ="00000000000 (NDCs are 11 digits long, but you can customize this to the length of your text string) I then saved the file as .txt
I hope this is helpful to someone with the same challenge.
steve    29 May 2014, 19:11
this is great!
Dave    27 Feb 2013, 20:34
Pete Wilson, you sir, are a champion.
Been looking for that solution everywhere.
Peggy    20 Sep 2012, 11:51
Thank you! I couldn't remember how to do this, then searched & searched, & I so appreciate your so clearly describing the process.
Pete Wilson    21 May 2012, 14:47
Apparently the only way is to convert the field to a string formula:

"=""string of data"""
frank     23 Mar 2012, 09:19
This is not a good solution as it requires intervention before loading the data. Is there a way to tell excel to leave the data as is when directly importing a .csv file?
Matheus    17 Nov 2011, 17:39
Great tip! Thank you.

Our Company

Sharon Parq Associates, Inc.

About Tips.Net

Contact Us


Advertise with Us

Our Privacy Policy

Our Sites


Beauty and Style




DriveTips (Google Drive)

ExcelTips (Excel 97–2003)

ExcelTips (Excel 2007–2016)



Home Improvement

Money and Finances


Pests and Bugs

Pets and Animals

WindowsTips (Microsoft Windows)

WordTips (Word 97–2003)

WordTips (Word 2007–2016)

Our Products

Helpful E-books

Newsletter Archives


Excel Products

Word Products

Our Authors

Author Index

Write for Tips.Net

Copyright © 2016 Sharon Parq Associates, Inc.