亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

批量導出access某表內容到word文檔

2019-11-14 13:54:20
字體:
來源:轉載
供稿:網友

一、需求:

 需要將表中每一條記錄中的某些內容導出在一個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 + "http://矢量數據//" + 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文檔了


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国内精品久久久久久| 中文字幕一区日韩电影| 欧美性猛交xxxx富婆| 青青草99啪国产免费| 91久久精品日日躁夜夜躁国产| 欧美乱大交xxxxx| 中文字幕日韩av电影| 日韩av在线电影网| 国产精品福利在线| 日韩av在线电影网| 国产一区二区三区在线观看网站| 欧美激情网站在线观看| 亚洲一区亚洲二区亚洲三区| 色婷婷综合久久久久中文字幕1| 亚洲а∨天堂久久精品喷水| 狠狠躁夜夜躁人人爽超碰91| 久久国产精品久久精品| 91香蕉国产在线观看| 91精品视频一区| 成人av在线亚洲| 精品视频久久久久久久| 国产精品九九久久久久久久| 欧美激情视频一区| 欧洲精品久久久| 亚洲精品电影在线| 成人欧美一区二区三区在线| 亚洲欧美日韩直播| 久久久国产一区二区三区| 成人免费视频在线观看超级碰| 97人人爽人人喊人人模波多| 亚洲欧美中文字幕在线一区| 91精品久久久久久久久久另类| 亚洲人成五月天| 亚洲欧美制服综合另类| 欧美性猛交xxxxx水多| 中日韩美女免费视频网址在线观看| 九色精品美女在线| 日韩中文字幕在线播放| 欧美在线观看网站| 亚洲韩国欧洲国产日产av| 51ⅴ精品国产91久久久久久| 国产精品久久久久久久久久东京| 日韩动漫免费观看电视剧高清| 欧美日韩中国免费专区在线看| 欧美视频专区一二在线观看| 欧美性xxxxxx| 欧美性猛交99久久久久99按摩| 日本欧美在线视频| 国产91在线播放精品91| 亚洲成人黄色网| 97视频在线播放| 亚洲男人天堂网站| 国产亚洲aⅴaaaaaa毛片| 国产精品自在线| 欧美性猛交99久久久久99按摩| 国产不卡av在线免费观看| 欧美老女人性生活| 欧美视频在线免费| 国内伊人久久久久久网站视频| 亚洲国产高潮在线观看| 欧美一级在线播放| 国产男女猛烈无遮挡91| 伊人精品在线观看| 欧美有码在线视频| 亚洲天堂av图片| 91干在线观看| 一区二区三区天堂av| 91在线免费看网站| 欧美日韩电影在线观看| 国产一区红桃视频| 欧美最顶级的aⅴ艳星| 亚洲国产成人精品久久| 国产一区二区三区四区福利| 日韩国产精品一区| 亚洲国产高潮在线观看| 成人美女免费网站视频| 久久久久久久久久久成人| 在线成人免费网站| 亚洲精品免费一区二区三区| 久久久久久国产精品三级玉女聊斋| 国内成人精品一区| 日韩av中文字幕在线免费观看| 久热国产精品视频| 国产精品高清网站| 九九视频这里只有精品| 日韩av在线免费播放| 黄色成人av网| 亚洲激情电影中文字幕| 精品一区二区三区电影| 性色av一区二区三区红粉影视| 久久全球大尺度高清视频| 色与欲影视天天看综合网| 国产91对白在线播放| 亚洲美女黄色片| 亚洲免费一在线| 国产精品亚洲美女av网站| 九色精品美女在线| 韩国精品美女www爽爽爽视频| 精品小视频在线| 17婷婷久久www| 日韩国产精品视频| 日韩欧美aaa| 色琪琪综合男人的天堂aⅴ视频| 日韩欧美黄色动漫| 日韩成人av网| 91精品视频在线播放| 亚洲国产一区二区三区四区| 亚洲人成网在线播放| 久久久久久久91| 国产成人鲁鲁免费视频a| 国产精品久久久久久亚洲影视| 亚洲视频自拍偷拍| 69视频在线播放| 欧美国产亚洲精品久久久8v| 国产精品国产三级国产aⅴ浪潮| 国产欧美日韩高清| 国产亚洲欧洲高清| 亚洲欧美日韩成人| 午夜精品福利视频| 亚洲第一视频网| 91香蕉嫩草影院入口| 欧美午夜片在线免费观看| 姬川优奈aav一区二区| 国产精品免费一区| 91精品国产综合久久久久久久久| 性欧美在线看片a免费观看| 国产精品7m视频| 精品国产拍在线观看| 国产欧洲精品视频| 国色天香2019中文字幕在线观看| 日本免费在线精品| 国产精品91久久| 国外成人在线视频| 九九热99久久久国产盗摄| 亚洲老头同性xxxxx| 欧美电影院免费观看| 欧美精品久久久久| 777精品视频| 久久99久久99精品中文字幕| 欧美wwwwww| 欧美二区乱c黑人| 亚洲一区久久久| 丁香五六月婷婷久久激情| 国产精品影片在线观看| 欧美亚洲国产成人精品| 国产精品久久久久久久久免费看| 亚洲免费av片| 日本高清不卡的在线| 一本大道久久加勒比香蕉| 亚洲国产精品成人精品| 欧美成人免费视频| 精品一区二区三区电影| 国产91免费看片| 亚洲激情在线视频| 成人性生交大片免费看小说| 欧美精品精品精品精品免费| 久久人人爽人人爽爽久久| 国产激情久久久| 精品亚洲男同gayvideo网站| 国产91精品在线播放| 亚洲欧美日本另类| 国模精品视频一区二区| 欧美性xxxxxxxxx| 成人欧美在线观看|