0

我不确定这里发生了什么。我使用此按钮事件将数据从 datagridview 导出到 excel 并导出数据、保存文件等,所以它看起来对我来说工作正常。

private void button2_Click(object sender, EventArgs e)
    {
        Microsoft.Office.Interop.Excel._Application app = new Microsoft.Office.Interop.Excel.Application();
        Microsoft.Office.Interop.Excel._Workbook workbook = app.Workbooks.Add(Type.Missing);
        Microsoft.Office.Interop.Excel._Worksheet worksheet = null;
        app.Visible = true;
        try
        {
            worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Sheets["Sheet1"];
            worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.ActiveSheet;
            worksheet.Name = "Gioietta Environment Data";
            for (int i = 1; i < dataGridView1.Columns.Count + 1; i++)
            {
                worksheet.Cells[1, i] = dataGridView1.Columns[i - 1].HeaderText;
            }
            for (int i = 0; i < dataGridView1.Rows.Count - 1; i++)
            {
                for (int j = 0; j < dataGridView1.Columns.Count; j++)
                {
                    worksheet.Cells[i + 2, j + 1] = dataGridView1.Rows[i].Cells[j].Value.ToString();
                }
            }
            string fileName = String.Empty;
            SaveFileDialog saveFileDialog1 = new SaveFileDialog();
            saveFileDialog1.Filter = "Excel files |*.xls|All files (*.*)|*.*";
            saveFileDialog1.FilterIndex = 2;
            saveFileDialog1.RestoreDirectory = true;

            if (saveFileDialog1.ShowDialog() == DialogResult.OK)
            {
                fileName = saveFileDialog1.FileName;
                workbook.SaveAs(fileName, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlExclusive, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
            }
            else
                return;               
        }
        catch (System.Exception ex)
        {

        }
        finally
        {
            app.Quit();
            workbook = null;
            app = null;
        }
    }

我遇到的问题是在 excel 方面。基本上即使将导出的值格式化为数字,我也无法使用它们。我什至无法总结它们!如果我手动在同一单元格中重新键入该值,它将变得可用。这与出口过程有关吗?

这就是我将数据加载到 datagridview 的方式:

var time = DateTime.Now.ToString("HH:mm:ss");
        dataGridView1.Rows.Add(new string[] { time, textBox1.Text, textBox2.Text });

在此处输入图像描述

4

1 回答 1

1

问题来自这一行以及 DataGridView 的填充方式:

worksheet.Cells[i   2, j   1] = dataGridView1.Rows[i].Cells[j].Value.ToString();

数据以string任何类型导出,.ToString()并且无论如何它们都是字符串。

AsDataGridViewCell.Value包含 a string,因此您必须在导出之前将 dgvCell.Value 转换为数值。例如:

if (j == 1 || j == 2) 
{
    worksheet.Cells(i   2, j   1) = Convert.ToDecimal(dataGridView1.Rows(i).Cells(j).Value)
} 
else 
{
    worksheet.Cells[i   2, j   1] = dataGridView1.Rows[i].Cells[j].Value.ToString();
}

如果 DataGridViewCell.Value 包含一个数值(Decimal、Double、Integer...),只需删除.toString()它,它应该可以按预期工作(Excel 将设置适当的类型)。

在这两种情况下,如果您想应用自定义格式以在 Excel 中显示,您将在导出过程中丢失它,并且您必须使用Range.NumberFormat属性在 Excel 中明确设置它。这些问答可以帮助实现这一目标:

于 2013-06-22T13:24:06.227 回答