数据库文件转化为excel文件

excel文件在日常生活中的作用毋庸置疑,面对小数据量,我们通常采用一一录入的方式,但是面对大量的数据的时候,我们可能就需要采用其他的办法。举个最近的例子:我们毕业设计的时候,论文选题没有使用教学管理系统,而是班委把纸质的题目集拿到班级,然后随机的抽取后汇总电子档交给院系,120多人,大量的数据需要录入,想必没有人愿意这样做~我想采用的做法是用ASP.NET制作一个网页,然后让同学登录网页,随机抽取题目,并将抽取的结果显示在页面上,等所有的同学抽取完毕,班委直接下载生成的excel表格即可。

下面是winform的演示结果

 

ContractedBlock.gif ExpandedBlockStart.gif mdf2xls
 
   
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
using System.IO;

namespace download
{
public partial class Form1 : Form
{
public void con()
{
SqlConnection downcon
= new SqlConnection();
downcon.ConnectionString
= @" Initial Catalog=stuinfo;Data Source=(local);Integrated Security=SSPI; User Instance = false " ;
downcon.Open();
SqlCommand downcom
= new SqlCommand( "" ,downcon);
downcom.CommandText
= @" select * from stucard " ;
SqlDataAdapter downda
= new SqlDataAdapter(downcom);
DataSet downset
= new DataSet();
downda.Fill(downset,
" stucard " );
dataGridView1.DataSource
= downset.Tables[ " stucard " ];
downcon.Close();
}

public Form1()
{
InitializeComponent();
con();

}

private void button1_Click( object sender, EventArgs e)
{
SaveFileDialog newdlg
= new SaveFileDialog();
newdlg.InitialDirectory
= @" C:\Documents and Settings\Administrator\桌面 " ;
newdlg.Filter
= " Execl files (*.xls)|*.xls " ;
newdlg.ShowDialog();
Stream myStream;
myStream
= newdlg.OpenFile();
StreamWriter sw
= new StreamWriter(myStream, System.Text.Encoding.GetEncoding( - 0 ));
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 - 1 ; j ++ )
{
string contentstr = "" ;
for ( int k = 0 ; k < dataGridView1.Columns.Count; k ++ )
{
if (k > 0 )
{
contentstr
+= " \t " ;
}
contentstr
+= dataGridView1.Rows[j].Cells[k].Value.ToString();
}
sw.WriteLine(contentstr);
}
sw.Close();
myStream.Close();
}
catch (Exception g)
{
MessageBox.Show(g.Message);
}
finally
{
sw.Close();
myStream.Close();
}
}

}
}

 

for (int i = 0; i < dataGridView1.ColumnCount; i++)
                {
                    if (i > 0)
                        str += "\t";
                    str += dataGridView1.Columns[i].HeaderText;
                }

 

上述代码是excel的列名,也是数据库的字段名称的生成。由于二者要对应,而且显示在excel的对应列上,这是\t是关键。

for (int j = 0; j < dataGridView1.Rows.Count-1; j++)
                {
                    string contentstr = "";
                    for (int k = 0; k < dataGridView1.Columns.Count; k++)
                    {
                        if (k > 0)
                        { 
                            contentstr += "\t"; 
                        }
                        contentstr += dataGridView1.Rows[j].Cells[k].Value.ToString();
                    }
                    sw.WriteLine(contentstr);
                }

 

值得注意的一点是j的上限,也就是数据的行数,在mdf数据库文件中,最后一行是全NULL,如果上限是dataGridView1.Rows.Count,而不是dataGridView1.Rows.Count-1的话,编译器检测到全NULL的数据时,会提示错误:未将对象引用设置到对象的实例。

2010072822092271.jpg

2010072822093680.jpg

转载于:https://www.cnblogs.com/doucontorl/archive/2010/07/28/mdf2xls.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值