How do I save data to a specific version of Excel in C#?

Posted on 2008-09-29
Last Modified: 2008-10-02
Below I have attached my present code which works fine, but saves data to an unrecognized Excel format.  When opening the file in Excel, the following error is produced:

"The file you are trying to open, 'filename.xls', is in a different format than specified by the file extension.  Verify that the file is not corrupted and is from a trusted source before opening the file.  Do you want to open the file now?"

Answering "Yes" causes the file to open normally.  But, I have another application that reads in Excel files and this format issue prevents the import of Excel data.  

Trying different parameters for the key line:

m_objBook.SaveAs(m_strSampleFolder + todaysDate + OrgSelection + ".xls", m_objOpt, m_objOpt, m_objOpt, m_objOpt, m_objOpt, Excel.XlSaveAsAccessMode.xlNoChange, m_objOpt, m_objOpt, m_objOpt, m_objOpt, m_objOpt);

has not yet revealed the solution.  Thoughts?

//************************************* The following code creates an excel spreadsheet and deposits data. *******************************

            // Start a new workbook in Excel.

            m_objExcel = new Excel.Application();

            m_objBooks = (Excel.Workbooks)m_objExcel.Workbooks;

            m_objBook = (Excel._Workbook)(m_objBooks.Add(m_objOpt));

            m_objSheets = (Excel.Sheets)m_objBook.Worksheets;

            m_objSheet = (Excel._Worksheet)(m_objSheets.get_Item(1));

            m_objSheet.Name = "GPS";

            // Create an array for the headers and add it to cells A1:L1.

            object[] objHeaders = { "AccountNumber", "Code", "Contract Price", "Date Time", "Extended Price", "ManualPrice", "NumberOfSets", "NumberOfSheets", "PO Number", "Project", "Size", "SqFeet Bond", "SqFeet Mylar", "SqFeet Vellum", "Total Sq ft" };

            m_objRange = m_objSheet.get_Range("A1", "L1");

            m_objRange.Value2 = objHeaders;

            m_objFont = m_objRange.Font;

            m_objFont.Bold = true;

            // Get array and add it to the worksheet starting at cell A1.

            m_objRange = m_objSheet.get_Range("A1", m_objOpt);

            m_objRange = m_objRange.get_Resize(20000, 15);

            m_objRange.Value2 = excelOutputArray;

            // Format cells to numeric format.  (remaining issue:  array data is string, need to create decimal valued array for numeric data)

            m_objRange = m_objSheet.get_Range("C2", "C20001");

            m_objRange.NumberFormat = "###0.0000";

            m_objRange = m_objSheet.get_Range("E2", "E20001");

            m_objRange.NumberFormat = "###0.0000";

            m_objRange = m_objSheet.get_Range("F2", "F20001");

            m_objRange.NumberFormat = "###0.0000";

            m_objRange = m_objSheet.get_Range("G2", "G20001");

            m_objRange.NumberFormat = "###0";

            m_objRange = m_objSheet.get_Range("H2", "H20001");

            m_objRange.NumberFormat = "###0";

            m_objRange = m_objSheet.get_Range("K2", "K20001");

            m_objRange.NumberFormat = "###0";

            m_objRange = m_objSheet.get_Range("L2", "L20001");

            m_objRange.NumberFormat = "###0.0000";

            m_objRange = m_objSheet.get_Range("M2", "M20001");

            m_objRange.NumberFormat = "###0.0000";

            m_objRange = m_objSheet.get_Range("N2", "N20001");

            m_objRange.NumberFormat = "###0.0000";

            m_objRange = m_objSheet.get_Range("O2", "O20001");

            m_objRange.NumberFormat = "###0.#";

            StartWizardBtn.Text = "Saving Data to Disk...";


            // Save the Workbook and quit Excel.

            m_objBook.SaveAs(m_strSampleFolder + todaysDate + OrgSelection + ".xls", m_objOpt, m_objOpt, m_objOpt, m_objOpt, m_objOpt, Excel.XlSaveAsAccessMode.xlNoChange, m_objOpt, m_objOpt, m_objOpt, m_objOpt, m_objOpt);

            m_objBook.Close(false, m_objOpt, m_objOpt);


            StartWizardBtn.Text = "Start Wizard";



Open in new window

Question by:dparkes

Accepted Solution

johnaryan earned 350 total points
Comment Utility
It depends on the verdion of the Excel Libraries your using.
The latest i think is Microsoft.Office.Interop.Excel Version 12.

Good Reference:

Author Comment

Comment Utility
The intended users will all be using a 2007 version of Excel.  Is there alternate code and/or methods that will allow a C# 2008 program to automatically save array data to a programmatically specified older Excel format (ie. Excel '97)?

Featured Post

Do You Know the 4 Main Threat Actor Types?

Do you know the main threat actor types? Most attackers fall into one of four categories, each with their own favored tactics, techniques, and procedures.

Join & Write a Comment

Extention Methods in C# 3.0 by Ivo Stoykov C# 3.0 offers extension methods. They allow extending existing classes without changing the class's source code or relying on inheritance. These are static methods invoked as instance method. This…
Introduction Although it is an old technology, serial ports are still being used by many hardware manufacturers. If you develop applications in C#, Microsoft .NET framework has SerialPort class to communicate with the serial ports.  I needed to…
It is a freely distributed piece of software for such tasks as photo retouching, image composition and image authoring. It works on many operating systems, in many languages.
Sending a Secure fax is easy with eFax Corporate ( First, Just open a new email message.  In the To field, type your recipient's fax number You can even send a secure international fax — just include t…

744 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now