使用互操作的CSV导出

时间:2010-09-20 09:39:27

标签: c# excel csv interop export

我正在使用此代码生成Excel文件。只需通过修改saveAs调用中的参数,将导出更改为CSV文件应该很简单,但它不起作用。任何想法为什么?

        Microsoft.Office.Interop.Excel.Application xlApp = new Microsoft.Office.Interop.Excel.Application();
        xlApp.Visible = false;
        if (xlApp == null)
        {
            MessageBox.Show("EXCEL could not be started. Check that your office installation and project references are correct.");
            return false;
        }
        Workbook wb = xlApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet);
        try
        {
            if (details != false)
            {
                //Workbook wb = xlApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet);
                wb.Worksheets.Add();
                Worksheet detailsWs = (Worksheet)wb.Worksheets[2];
                for (int i = 0; i < dt.Columns.Count; i++)
                {
                    detailsWs.Cells[1, i + 1] = dt.Columns[i].Caption;
                }
            }
            Worksheet ws = (Worksheet)wb.Worksheets[1];
            if (ws == null)
            {
                MessageBox.Show("Worksheet could not be created. Check that your office installation and project references are correct.");
            }
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                ws.Cells[1, i + 1] = dt.Columns[i].Caption;
            }
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                for (int j = 0; j < dt.Columns.Count; j++)
                {
                    ws.Cells[i + 2, j + 1] = dt.Rows[i].ItemArray[j];
                }
                worker.ReportProgress((i * 100) / dt.Rows.Count);
            }

            wb.SaveAs(filename, XlFileFormat.xlCSV, Type.Missing, Type.Missing, Type.Missing, Type.Missing, XlSaveAsAccessMode.xlShared, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
            wb.Close(true, filename);

            return true;
        }
        catch (Exception ex)
        {
            throw ex;
        }
        finally
        {
            // Cleanup
            GC.Collect();
            GC.WaitForPendingFinalizers();
            GC.Collect();
            GC.WaitForPendingFinalizers();
            if (wb != null)
            {
                wb.Close(Type.Missing, Type.Missing, Type.Missing);
                Marshal.FinalReleaseComObject(wb);
            }
            if (xlApp != null)
            {
                xlApp.Quit();
                Marshal.FinalReleaseComObject(xlApp);
            }
        }

2 个答案:

答案 0 :(得分:2)

我用旧的方式。字符串,用逗号

答案 1 :(得分:2)

XlSaveAsAccessMode.xlShared是原因。我不知道为什么,但我也得到了这个错误。 我尝试更改XlSaveAsAccessMode.xlNoChangeXlSaveAsAccessMode.xlExclusive

有效!