在Winform中使用NPOI第三方元件匯出Excel
最近使用NPOI匯出Datagridview資料。。。。。。
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 DLZY;
using NPOI;
using NPOI.POIFS;
using NPOI.HSSF;
using NPOI.HPSF;
using NPOI.Util;
using NPOI.HSSF.UserModel;
using NPOI.POIFS.FileSystem;
using System.IO;
using NPOI.SS.UserModel;
using Model;
using DAL;
namespace 收入查詢
{
public partial class Form2 : Form
{
public Form2()
{
InitializeComponent();
}
private void Form2_Load(object sender, EventArgs e)
{
}
private void Bind()
{
SqlConnection conn = SqlHelper.Conn(); //連線資料庫
//string sql = string.Format("select * from Income_Note where IncomeType ='{0}' and IncomeTime between '{1}' and '{2}'", srtype.Text, Convert.ToDateTime(kstime.Text), Convert.ToDateTime(jstime.Text));
string sql = "select * from Income_Note where IncomeType =@IncomeType and IncomeTime between @Start and @End ";
SqlDataAdapter ad = new SqlDataAdapter(sql, conn); //提交查詢命令
ad.SelectCommand.Parameters.AddWithValue("@IncomeType", srtype.Text);
ad.SelectCommand.Parameters.AddWithValue("@Start", Convert.ToDateTime(kstime.Text));
ad.SelectCommand.Parameters.AddWithValue("@End", Convert.ToDateTime(jstime.Text));
DataTable dt = new DataTable(); //新建表
ad.Fill(dt);
srdata.DataSource = dt;// 顯示收入查詢返回的dt表結果到。。。
}
private void button1_Click(object sender, EventArgs e)
{
if (srtype.Text.Trim() != string.Empty)
{
Bind();
}
else
{
MessageBox.Show("資訊有誤,請輸入正確的的值!");
}
}
private void button3_Click(object sender, EventArgs e)
{
Form3 frm3= new Form3();
frm3.ShowDialog();
}
private void button4_Click(object sender, EventArgs e)
{
if (srdata.SelectedRows.Count == 0)
{
MessageBox.Show("沒有選擇有效行");
return;
}
else if (MessageBox.Show("你確定要刪除嗎?", "警告", MessageBoxButtons.YesNoCancel) == DialogResult.Yes)
{
SqlConnection conn = SqlHelper.Conn();
conn.Open();
string sql = "delete from Income_Note where IncomeId=@id";
SqlCommand comm = new SqlCommand(sql, conn);
comm.Parameters.AddWithValue("id", srdata.SelectedRows[0].Cells["colid"].Value.ToString());
comm.ExecuteNonQuery();
conn.Close();
Bind();
MessageBox.Show("刪除成功");
}
else
{
return;
}
}
private void button2_Click(object sender, EventArgs e)
{
this.Close();
}
private void btnExport_Click(object sender, EventArgs e)
{
//ExportTOExcel(srdata);
SaveFileDialog sdfexport = new SaveFileDialog();
sdfexport.Filter = "Excel檔案|*.xls";
if (sdfexport.ShowDialog() == DialogResult.No)
{
return;
}
string filename = sdfexport.FileName;
HSSFWorkbook workbook = new HSSFWorkbook();
ISheet sheet = workbook.CreateSheet("支出資料");
IRow rowHeader = sheet.CreateRow(0);
rowHeader.CreateCell(0, CellType.STRING).SetCellValue("ID");
rowHeader.CreateCell(1, CellType.STRING).SetCellValue("使用者姓名");
rowHeader.CreateCell(2, CellType.STRING).SetCellValue("收入方式");
rowHeader.CreateCell(3, CellType.STRING).SetCellValue("收入時間");
rowHeader.CreateCell(4, CellType.STRING).SetCellValue("收入金額");
rowHeader.CreateCell(5, CellType.STRING).SetCellValue("備註");
sheet.SetColumnWidth(3, 20 * 256);
string sql = "select * from Income_Note where IncomeType =@IncomeType and IncomeTime between @Start and @End ";
List<SqlParameter> paramsList = new List<SqlParameter>();
paramsList.Add(new SqlParameter("@IncomeType", srtype.Text));
paramsList.Add(new SqlParameter("@Start", Convert.ToDateTime(kstime.Text)));
paramsList.Add(new SqlParameter("@End", Convert.ToDateTime(jstime.Text)));
Income_Note[] incomenotes = new IncomeNoteDAL().Search(sql, paramsList);
for (int i = 0; i < incomenotes.Length; i++)
{
Income_Note incomenote = incomenotes[i];
IRow row = sheet.CreateRow(i + 1);
row.CreateCell(0, CellType.NUMERIC).SetCellValue(incomenote.IncomeId);
row.CreateCell(1, CellType.STRING).SetCellValue(incomenote.UserName);
row.CreateCell(2, CellType.STRING).SetCellValue(incomenote.IncomeType);
ICellStyle styledate = workbook.CreateCellStyle();
IDataFormat format = workbook.CreateDataFormat();
styledate.DataFormat = format.GetFormat("yyyy\"年\"m\"月\"d\"日\"");
ICell cellDate = row.CreateCell(3, CellType.NUMERIC);
cellDate.CellStyle = styledate;
cellDate.SetCellValue(incomenote.IncomeTime);
HSSFCellStyle cellStyle2 = (HSSFCellStyle)workbook.CreateCellStyle();
HSSFDataFormat format2 = (HSSFDataFormat)workbook.CreateDataFormat();
//cellStyle2.DataFormat = format2.GetFormat("¥#,##0");
cellStyle2.DataFormat = format2.GetFormat("¥#,##0;¥-#,##0");
HSSFCell cellMoney = (HSSFCell)row.CreateCell(4, CellType.NUMERIC);
cellMoney.CellStyle = cellStyle2;
cellMoney.SetCellValue(incomenote.IncomeMoney.ToString());
row.CreateCell(5, CellType.STRING).SetCellValue(incomenote.IncomeNote);
}
using (Stream stream = File.OpenWrite(filename))
{
workbook.Write(stream);
}
}
}
}
截圖如下所示:
匯出xsl如下:
相關文章
- NPOI匯出和匯入Excel,Word和PDFExcel
- 分享:一個基於NPOI的excel匯入匯出元件(強型別)Excel元件型別
- C# 實現NPOI的Excel匯出C#Excel
- 基於NPOI封裝匯出Excel方法封裝Excel
- 基於EPPlus和NPOI實現的Excel匯入匯出Excel
- 基於Vue + axios + WebApi + NPOI匯出Excel檔案VueiOSWebAPIExcel
- NPOI 在指定單元格匯入匯出圖片
- .NET Core使用NPOI將Excel中的資料批量匯入到MySQLExcelMySql
- .Net Core Excel匯入匯出神器Npoi.MapperExcelAPP
- NPOI建立並匯出word
- 使用WeihanLi.Npoi操作ExcelExcel
- Go 使用反射匯出 ExcelGo反射Excel
- Mvc 5中匯出ExcelMVCExcel
- 如何使用 JavaScript 匯入和匯出 ExcelJavaScriptExcel
- 在WPF中使用WinForm控制元件方法ORM控制元件
- 匯出excelExcel
- 關於java中Excel的匯入匯出JavaExcel
- 使用 Laravel-Excel 和流的方法匯出 ExcelLaravelExcel
- maatwebsite/Excel 3.1 使用教程 (匯出篇)WebExcel
- 使用Magicodes.IE快速匯出ExcelExcel
- Element-ui元件庫Table表格匯出Excel表格UI元件Excel
- 如何使用JavaScript匯入和匯出Excel檔案JavaScriptExcel
- java使使用者EasyExcel匯入匯出excelJavaExcel
- Laravel5.6中使用Laravel/Excel實現Excel檔案匯出功能LaravelExcel
- vue excel匯入匯出VueExcel
- Java匯出ExcelJavaExcel
- Vue匯出ExcelVueExcel
- PHP 匯出 ExcelPHPExcel
- PHP匯出EXCELPHPExcel
- Excel操作-NPOI截圖Excel
- 使用vue匯出excel遇到的那些坑VueExcel
- POI的使用及匯出excel報表Excel
- C# 使用Aspose.Cells 匯出ExcelC#Excel
- Dcat admin使用Laravel Excel匯出資料LaravelExcel
- 使用xlsx file-saver exceljs實現瀏覽器中Excel匯入匯出ExcelJS瀏覽器
- java匯出Excel定義匯出模板JavaExcel
- Excel模板匯出之動態匯出Excel
- C# Aspx Web 匯出Excel2007-xlsx格式檔案用NPOI外掛的問題C#WebExcel
- Angular Excel 匯入與匯出AngularExcel