C# 將datagridview 資料匯出到Excel、word

來源:互聯網
上載者:User
匯出到Excel方法

 //匯出到Excel方法        public bool ExportDataGridviewExcel(DataGridView gridview,bool isShowExcel)         {            if (gridview.Rows.Count==0)            {                return false;            }            //建立Excel對象            Excel.Application excel = new Excel.Application();            excel.Application.Workbooks.Add(true);            excel.Visible = isShowExcel;            //產生欄位名稱            for (int i = 0; i < gridview.Columns.Count; i++)            {                excel.Cells[1, i + 1] = gridview.Columns[i].HeaderText;            }            //填充資料            for (int i = 0; i < gridview.Rows.Count-1; i++)            {                for (int j = 0; j < gridview.Columns.Count; j++)                {                    if (gridview[j,i].ValueType==typeof(string))                    {                        excel.Cells[i+2,j+1]=""+gridview[j,i].Value.ToString();                    }                    else                    {                        excel.Cells[i + 2, j + 1] = gridview[j, i].Value.ToString();                    }                }            }            return true;        }

 

匯出到Word方法

//匯出到Word方法        public bool ExportDataGridviewWord(DataGridView gridview, bool isShowExcel)        {            if (gridview.Rows.Count == 0)            {                return false;            }            Word.Document mydoc = new Word.Document();            Word.Table mytable;            Word.Selection mysel;            Object myobj;            //建立Word對象            Word.Application word = new Word.Application();            myobj = System.Reflection.Missing.Value;            mydoc = word.Documents.Add(ref myobj, ref myobj, ref myobj, ref myobj);            word.Visible = isShowExcel;            mydoc.Select();            mysel = word.Selection;            //將資料產生Word表格檔案            mytable = mydoc.Tables.Add(mysel.Range, this.dataGridView1.RowCount, this.dataGridView1.ColumnCount, ref myobj, ref myobj);            //設定列寬            mytable.Columns.SetWidth(30, Word.WdRulerStyle.wdAdjustNone);            //輸出資料行標題資料            for (int i = 0; i < this.dataGridView1.ColumnCount; i++)            {                mytable.Cell(1, i + 1).Range.InsertAfter(this.dataGridView1.Columns[i].HeaderText);            }            //輸出控制項中的記錄            for (int i = 0; i < this.dataGridView1.RowCount - 1; i++)            {                for (int j = 0; j < this.dataGridView1.ColumnCount; j++)                {                    mytable.Cell(i + 2, j + 1).Range.InsertAfter(this.dataGridView1[j, i].Value.ToString());                }            }            return true;        }

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.