C#datagridview导出Excel其中身份证号码字段为文本格式,而不是科学计数法格式

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#datagridview导出Excel其中身份证号码字段为文本格式,而不是科学计数法格式相关的知识,希望对你有一定的参考价值。

//利用Stream(流)的方式
SaveFileDialog saveFileDialog = new SaveFileDialog();
saveFileDialog.Filter = "Execl files (*.xls)|*.xls";
saveFileDialog.FilterIndex = 0;
saveFileDialog.RestoreDirectory = true;
saveFileDialog.CreatePrompt = true;
saveFileDialog.Title = "导出Excel文件到";

DateTime now = DateTime.Now;
saveFileDialog.FileName = now.Year.ToString().PadLeft(2)
+ now.Month.ToString().PadLeft(2, '0')
+ now.Day.ToString().PadLeft(2, '0') + "-"
+ now.Hour.ToString().PadLeft(2, '0')
+ now.Minute.ToString().PadLeft(2, '0')
+ now.Second.ToString().PadLeft(2, '0');

saveFileDialog.ShowDialog();

Stream myStream;
myStream = saveFileDialog.OpenFile();
StreamWriter sw = new StreamWriter(myStream, System.Text.Encoding.GetEncoding("gb2312"));
string str = "";
try

//写标题
for (int i = 0; i < dataGridview1.ColumnCount; i++)

if (i > 0)

str += "\t";

str += dataGridview1.Columns[i].HeaderText;


sw.WriteLine(str);
//写内容
for (int j = 0; j < dataGridview1.Rows.Count; j++)

string tempStr = "";
for (int k = 0; k < dataGridview1.Columns.Count; k++)

if (k > 0)

tempStr += "\t";

tempStr += dataGridview1.Rows[j].Cells[k].Value.ToString();

sw.WriteLine(tempStr);

sw.Close();
myStream.Close();
MessageBox.Show("成功导出Excel");

catch (Exception e)

MessageBox.Show(e.ToString());

finally

sw.Close();
myStream.Close();


这是源代码,求高手,大师!

参考技术A 自定义单元格,数据类型设置为18个0,就可以了吧。

c# winform DataGridView导出数据到Excel中,可以导出当前页和全部数据

准备工作就是可以分页的DataGridView,和两个按钮,一个用来导出当前页数据到Excel,一个用来导出全部数据到Excel

没有使用SaveFileDialog,但却可以弹出保存对话框来

先做导出当前页数据到Excel的

DataGridView命名为dataGridView1

技术图片
 1 //按下导出按钮  
 2 private void button7_Click(object sender, EventArgs e)  
 3   
 4     print(dataGridView1);  
 5   
 6 public void print(DataGridView dataGridView1)  
 7   
 8     //导出到execl  
 9     try  
10       
11         //没有数据的话就不往下执行  
12         if (dataGridView1.Rows.Count == 0)  
13             return;  
14         //实例化一个Excel.Application对象  
15         Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();  
16   
17         //让后台执行设置为不可见,为true的话会看到打开一个Excel,然后数据在往里写  
18         excel.Visible = false;  
19                   
20         //新增加一个工作簿,Workbook是直接保存,不会弹出保存对话框,加上Application会弹出保存对话框,值为false会报错  
21     excel.Application.Workbooks.Add(true);                
22         //生成Excel中列头名称  
23         for (int i = 0; i < dataGridView1.Columns.Count; i++)  
24           
25             excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;  
26           
27         //把DataGridView当前页的数据保存在Excel中  
28         for (int i = 0; i < dataGridView1.Rows.Count - 1; i++)  
29           
30             for (int j = 0; j < dataGridView1.Columns.Count; j++)  
31               
32                 if (dataGridView1[j, i].ValueType == typeof(string))  
33                   
34                     excel.Cells[i + 2, j + 1] = "" + dataGridView1[j, i].Value.ToString();  
35                   
36                 else  
37                   
38                     excel.Cells[i + 2, j + 1] = dataGridView1[j, i].Value.ToString();  
39                   
40               
41           
42   
43         //设置禁止弹出保存和覆盖的询问提示框  
44         excel.DisplayAlerts = false;  
45         excel.AlertBeforeOverwriting = false;  
46   
47         //保存工作簿  
48         excel.Application.Workbooks.Add(true).Save();  
49         //保存excel文件  
50         excel.Save("D:" + "\\KKHMD.xls");  
51                       
52         //确保Excel进程关闭  
53         excel.Quit();  
54         excel = null;  
55   
56       
57     catch (Exception ex)  
58       
59         MessageBox.Show(ex.Message, "错误提示");  
60       
61   
View Code

导出从数据库中查询到的所有的数据到Excel中

技术图片
 1 #region 导出全部数据到Excel中,可弹出保存对话框,但没用SaveFileDialog  
 2   
 3 public void printAll(System.Data.DataTable dt)  
 4   
 5     //导出到execl  
 6     try  
 7       
 8         //没有数据的话就不往下执行  
 9         if (dt.Rows.Count == 0)  
10             return;  
11         //实例化一个Excel.Application对象  
12         Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();  
13   
14         //新增加一个工作簿,Workbook是直接保存,不会弹出保存对话框,加上Application会弹出保存对话框,值为false会报错  
15         excel.Application.Workbooks.Add(true);  
16   
17         //让后台执行设置为不可见,为true的话会看到打开一个Excel,然后数据在往里写  
18         excel.Visible = false;  
19         //生成Excel中列头名称  
20         for (int i = 0; i < dt.Columns.Count; i++)  
21           
22             excel.Cells[1, i + 1] = dataGridView1.Columns[i].HeaderText;//输出DataGridView列头名  
23           
24   
25         //把DataGridView当前页的数据保存在Excel中  
26         if (dt.Rows.Count > 0)  
27           
28             for (int i = 0; i < dt.Rows.Count; i++)//控制Excel中行,上下的距离,就是可以到Excel最下的行数,比数据长了报错,比数据短了会显示不完  
29               
30                 for (int j = 0; j < dt.Columns.Count; j++)//控制Excel中列,左右的距离,就是可以到Excel最右的列数,比数据长了报错,比数据短了会显示不完  
31                   
32                     string str = dt.Rows[i][j].ToString();  
33                     excel.Cells[i + 2, j + 1] = "" + str;//i控制行,从Excel中第2行开始输出第一行数据,j控制列,从Excel中第1列输出第1列数据,"‘" +是以string形式保存,所以遇到数字不会转成16进制  
34                   
35               
36           
37         //设置禁止弹出保存和覆盖的询问提示框  
38         excel.DisplayAlerts = false;  
39         excel.AlertBeforeOverwriting = false;  
40   
41         //保存工作簿,值为false会报错  
42         excel.Application.Workbooks.Add(true).Save();  
43         //保存excel文件  
44         excel.Save("D:" + "\\KKHMD.xls");  
45   
46         //确保Excel进程关闭  
47         excel.Quit();  
48         excel = null;  
49   
50       
51     catch (Exception ex)  
52       
53         MessageBox.Show(ex.Message, "错误提示");  
54       
55   
56 private void button1_Click(object sender, EventArgs e)  
57   
58     printAll(dt);  
59   
60  
61 #endregion  
View Code

这不是最好的版本,无论是功能上还是效率上,至少没用SaveFileDialog的话,控制不到取消保存按钮,一旦点击了取消保存,则软件重起之前一直都不能再使用导出功能,只能是手动杀掉进程中的Excel.exe,进程中的Excel.exe也是没有在程序里进行关闭的,所以是使用一次导出功能,就会在进程中多生成一次Excel.exe

以上是关于C#datagridview导出Excel其中身份证号码字段为文本格式,而不是科学计数法格式的主要内容,如果未能解决你的问题,请参考以下文章

C#中datagridview导出Excel将身份证号设置为文本格式,而不是科学计数法格式

C#winform中datagridview导出Excel

各位仁兄,我想请教一下在C#winform中,datagridview如何导出excel文件,将excel导入datagridview.

C#winform中如何把表导出到EXCEL

C#winform 两个datagridview中的数据一键导出到同一个excel中两个sheet页里

请问谁有C#datagridview导出csv格式的excel的代码啊,发一下学习学习?