asp.net中如何批量导出access某表内容到word文档

 更新时间:2015年10月15日 14:38:33   投稿:mrr  
最近有项目需求是这样的,需要将某表中的每一条记录中的某些内容导出在一个word文档中。下面小编就把我的解决办法分享给大家,供大家参考

下面通过图文并茂的方式给大家介绍asp.net中批量导出access某表内容到word文档的方法,具体详情如下:

一、需求:

 需要将表中每一条记录中的某些内容导出在一个word文档中,并将这些文档保存在指定文件夹目录下

二、界面,简单设计如下:

三、添加office相关引用

添加后可在解决方案资源管理器中看到:

四、添加form1中的引用

using System.Data.OleDb;
using System.Data.SqlClient;
using System.IO;
using Microsoft.Office.Core;
using Word=Microsoft.Office.Interop.Word;
using System.Reflection;

五、窗体Form1中代码如下:

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.OleDb;
using System.Data.SqlClient;
using System.IO;
using Microsoft.Office.Core;
using Word=Microsoft.Office.Interop.Word;
using System.Reflection;
using System.Threading;//线程需用,进程中
namespace word
{
 delegate void ShowProgressDelegate(int totalStep, int currentStep); //定义委托,异步调用
 public partial class Form1 : Form
 {
  public Form1()
  {
   InitializeComponent();
  }
  public string filepath = "D:\\zjy\\其他\\NCTDCBJYQ04.mdb"; //数据库所在位置设置
  public string path; //输出路径
  private void Form1_Load(object sender, EventArgs e)
  {
   string sqlstr = "select OBJECTID,CBFBM,CBFMC from CBF";
   //string sqlstr = "select * from CBF";
   DataSet ds = AccessDAO.getDataSetFromAccessTable(sqlstr, filepath);
   this.dataGridView1.DataSource = ds.Tables[0].DefaultView; 
   dataGridView1.AllowUserToAddRows = false;
  }
  private void textBox1_MouseClick(object sender, MouseEventArgs e)//输出路径设置
  {
   FolderBrowserDialog dilog = new FolderBrowserDialog();
   dilog.Description = "请选择文件夹";
   if (dilog.ShowDialog() == DialogResult.OK || dilog.ShowDialog() == DialogResult.Yes)
   {
    path = dilog.SelectedPath;
    this.textBox1.Text = path;
   }
  }
  object pathword;      //声明文件路径变量
  private void button2_Click(object sender, EventArgs e) //批量输出
  {
   ParameterizedThreadStart start = new ParameterizedThreadStart(SetProgress);
   Thread progressThread = new Thread(start);
   progressThread.IsBackground = true;//标记为后台进程,在窗口退出时,正常退出
   progressThread.Start();
  }
   /// <summary>
  /// 刷新进度条
  /// </summary>
  /// <param name="totalStep"></param>
  /// <param name="currentStep"></param>
  void ShowProgress(int totalStep, int currentStep)
  {
   this.progressBar1.Maximum = totalStep;
   this.progressBar1.Value = currentStep;
   if (this.progressBar1.Value * 100 / progressBar1.Maximum != 100)
   {
    this.label2.Text = "当前输出进度为:" + this.progressBar1.Value * 100 / progressBar1.Maximum + "%" + " 请耐心等待:)";
   }
   else if (this.progressBar1.Value * 100 / progressBar1.Maximum == 100)
   {
    this.label2.Text = "输出结束!";
   }
  }
  /// <summary>
  /// 设置当前进度
  /// </summary>
  /// <param name="state"></param>
  void SetProgress(object state)
  {
   if (this.textBox1.Text == "")
   {
    MessageBox.Show("请选择文件输出路径", "提示");
   }
   else
   {
    for (int i = 0; i < this.dataGridView1.Rows.Count; i++) //遍历获取table中需要的值,并分别创建word文档
    {
     #region 打开进度条
     Thread.Sleep(1);
     object[] objs = new object[] { this.dataGridView1.RowCount, i+1 };
     //异步调用
     this.Invoke(new ShowProgressDelegate(ShowProgress), objs);
     #endregion
     #region 获取word中需要添加的内容
     string dm = this.dataGridView1.Rows[i].Cells[1].Value.ToString();//承包方编码
     string mc = this.dataGridView1.Rows[i].Cells[2].Value.ToString();//承包方名称
     #endregion
     #region 创建word文档,并将内容写入word,并保存起来
     //初始化变量
     object Nothing = Missing.Value;      //COM调用时用于占位
     object format = Word.WdSaveFormat.wdFormatDocument; //Word文档的保存格式
     Word.ApplicationClass wordApp = new Word.ApplicationClass();    //声明一个wordAPP对象
     Word.Document worddoc = wordApp.Documents.Add(ref Nothing, ref Nothing, ref Nothing, ref Nothing);//新建一个word对象
     //向文档中写入内容
     string wordstr = "承包方代码:" + dm + "\n" + "承包方名称:" + mc;
     worddoc.Paragraphs.Last.Range.Text = wordstr;
     //保存文档   
     pathword = path + "\\" + dm; //设置文件保存路径
     worddoc.SaveAs(ref pathword, ref format, ref Nothing, ref Nothing,
      ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing,
      ref Nothing, ref Nothing, ref Nothing, ref Nothing,
      ref Nothing, ref Nothing, ref Nothing);
     //关闭文档
     worddoc.Close(ref Nothing, ref Nothing, ref Nothing); //关闭worddoc文档对象
     wordApp.Quit(ref Nothing, ref Nothing, ref Nothing); //关闭wordApp组对象
     #endregion
    }
    MessageBox.Show("文档创建成功!","提示");
   }   
  }    
 }
}

六、读取数据库中表需要的数据库类AccessDAO.cs代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.Data.OleDb;
using System.Data.SqlClient;
using System.Text.RegularExpressions; //正则表达式引用所需
namespace word
{
 //access的数据访问接口
 class AccessDAO
 {
  public static class Property
  {
   public static string accessFilePath = "d:\\nCTDCBJYQ04DataSet.mdb";
   //若放入主程序,则可如下设置
   //one mainFrm = (one)this.Owner;
   //string prjName = mainFrm.laPrj.Text;
   //string prjPath = mainFrm.laFile_Path.Text;
   // public static string accessFilePath = prjPath + "\\矢量数据\\" + prjName + ".mdb";
  }
  //从access数据库获取数据
  //dataFilePath指定access文件的路径
  //sql指定数据库的查询语句
  //DataSet为查询返回的数据集
  public static DataSet getDataSetFromAccessTable(string sql, string dataFilePath)
  {
   // 连接数据库 
   OleDbConnection connct = new OleDbConnection();
   string oleDB = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + dataFilePath;
   connct.ConnectionString = oleDB;
   //创建命令
   OleDbCommand command = new OleDbCommand(sql, connct);
   //打开数据库
   connct.Open();
   //执行命令
   DataSet dataSet = new DataSet();
   OleDbDataAdapter dataAdapter = new OleDbDataAdapter(command);
   dataAdapter.Fill(dataSet);
   // 关闭连接 
   connct.Close();
   return dataSet;
  }
  //更新或者插入数据到access数据库
  //dataFilePath指定access文件的路径
  //sql指定数据库的更新或者插入语句
  //返回值int表示此次更新影响的行数
  public static int updateAccessTable(string sql, string dataFilePath)
  {
   // 连接数据库 
   OleDbConnection connct = new OleDbConnection();
   string oleDB = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + dataFilePath;
   connct.ConnectionString = oleDB;
   //打开数据库
   connct.Open();
   //执行命令
   OleDbCommand myCommand = new OleDbCommand(sql, connct);
   int res = myCommand.ExecuteNonQuery();
   // 关闭连接 
   connct.Close();
   return res;
  }
  //更新或者插入数据到access数据库
  //dataFilePath指定access文件的路径
  //command指定操作(更新或者插入)数据库的命令
  //返回值int表示此次更新影响的行数
  public static int updateAccessTable(OleDbCommand command, string dataFilePath)
  {
   // 连接数据库 
   OleDbConnection connct = new OleDbConnection();
   string oleDB = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + dataFilePath;
   connct.ConnectionString = oleDB;
   //打开数据库
   connct.Open();
   //执行命令
   //OleDbCommand myCommand = new OleDbCommand(sql, connct);
   command.Connection = connct;
   int res = command.ExecuteNonQuery();
   // 关闭连接 
   connct.Close();
   return res;
  }
  public bool ckDigital_Num(string digitalItem, int digitalNum)    //正则检查是否为数字,且位数一定
  {
   bool isDigital_Num = false;
   Regex reGen = new Regex(@"^\d{" + digitalNum.ToString("F0") + "}$");     //正则表达式,n位数字
   if (reGen.IsMatch(digitalItem))
    isDigital_Num = true;
   return isDigital_Num;
  }
 }
}

ok了,至此就可完成批量导出成word文档了

相关文章

  • ashx介绍以及ashx文件与aspx文件之间的区别

    ashx介绍以及ashx文件与aspx文件之间的区别

    这篇文章主要介绍了ashx以及ashx文件与aspx文件之间的区别。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-12-12
  • 基于.Net Core认证授权方案之JwtBearer认证

    基于.Net Core认证授权方案之JwtBearer认证

    这篇文章介绍了基于.Net Core认证授权方案之JwtBearer认证,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • .Net基于MVC4 Web Api输出Json格式实例

    .Net基于MVC4 Web Api输出Json格式实例

    这篇文章主要介绍了.Net基于MVC4 Web Api输出Json格式的实现方法,实例讲述了Global中json的操作与XML的处理等技巧,需要的朋友可以参考下
    2014-10-10
  • ASP.NET Core3.1 Ocelot认证的实现

    ASP.NET Core3.1 Ocelot认证的实现

    这篇文章主要介绍了ASP.NET Core3.1 Ocelot认证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • C#实现pdf导出 .Net导出pdf文件

    C#实现pdf导出 .Net导出pdf文件

    这篇文章主要为大家详细介绍了C#实现pdf导出 .Net导出pdf文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 如何将数据绑到gridview然后导成excel

    如何将数据绑到gridview然后导成excel

    这篇文章主要介绍了如何将数据绑到gridview然后导成excel,需要的朋友可以参考下
    2014-02-02
  • asp.net core调用wps实现word转pdf的过程

    asp.net core调用wps实现word转pdf的过程

    这篇文章主要介绍了asp.net core调用wps实现word转pdf的过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-08-08
  • asp.net音频转换之.amr转.mp3(利用七牛转换法)

    asp.net音频转换之.amr转.mp3(利用七牛转换法)

    相信很多人都遇到amr格式的音频文件不能直接在网页播放的问题,有人使用QuickTime插件的辅助,下面这篇文章主要给大家介绍了asp.net音频转换之利用七牛转换法将.amr格式转.mp3格式,需要的朋友可以参考借鉴,下面来一起看看吧。
    2016-12-12
  • asp.net图片上传实例

    asp.net图片上传实例

    网站后台都需要有上传图片的功能,下面的例子就是实现有关图片上传。缺点:图片上传到本服务器上,不适合大量图片上传
    2013-12-12
  • ASP.NET TreeView读取数据库实例

    ASP.NET TreeView读取数据库实例

    这篇文章主要介绍了ASP.NET TreeView读取数据库实例,有需要的朋友可以参考一下
    2013-11-11

最新评论