如何将Winfrom中的数据导入固定的excel模版中C#

从winform中输入信息,然后将信息导入以上表中,从表中第三行开始导入信息,这个要怎么实现啊,谢谢了

c#的代码如下:
#region 导入excel数据
private void button2_Click(object sender, EventArgs e)
{
OpenFileDialog openFileDialog = new OpenFileDialog();
openFileDialog.Filter = "表格文件 (*.xls)|*.xls";
openFileDialog.RestoreDirectory = true;
openFileDialog.FilterIndex = 1;
if (openFileDialog.ShowDialog() == DialogResult.OK)
{
Import(openFileDialog.FileName);
}
}

/// <summary>
/// 导入excel数据
/// </summary>
/// <param name="filePath"></param>
/// <returns></returns>
public static bool Import(string filePath)
{
try
{
//Excel就好比一个数据源一般使用
//这里可以根据判断excel文件是03的还是07的,然后写相应的连接字符串
string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + filePath + ";" + "Extended Properties=Excel 8.0;";
OleDbConnection con = new OleDbConnection(strConn);
con.Open();
string[] names = GetExcelSheetNames(con);
if (names.Length > 0)
{
foreach (string name in names)
{
OleDbCommand cmd = con.CreateCommand();
cmd.CommandText = string.Format(" select * from [{0}]", name);//[sheetName]要如此格式
OleDbDataReader odr = cmd.ExecuteReader();
while (odr.Read())
{
if (odr[0].ToString() == "序号")//过滤列头 按你的实际Excel文件
continue;
//数据库添加操作
/*进行非法值的判断
* 添加数据到数据表中
* 添加数据时引用事物机制,避免部分数据提交
* Add(odr[1].ToString(), odr[2].ToString(), odr[3].ToString());//数据库添加操作,Add方法自己写的
* */

}
odr.Close();
}
}
return true;
}
catch (Exception)
{
return false;
}
}

/// <summary>
/// 查询表名
/// </summary>
/// <param name="con"></param>
/// <returns></returns>
public static string[] GetExcelSheetNames(OleDbConnection con)
{
try
{
System.Data.DataTable dt = con.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new[] { null, null, null, "Table" });//检索Excel的架构信息
var sheet = new string[dt.Rows.Count];
for (int i = 0, j = dt.Rows.Count; i < j; i++)
{
//获取的SheetName是带了$的
sheet[i] = dt.Rows[i]["TABLE_NAME"].ToString();
}
return sheet;
}
catch
{
return null;
}
}

//下面这种方法获取excel Worksheets Name时,提示无法访问该exceL文件,所以改为上面获取工作簿名的方式

///// <summary>
///// 获得excel sheet所有工作簿名字
///// </summary>
///// <param name="filePath"></param>
///// <returns></returns>
//public static string[] GetExcelSheetNames(string filePath)
//{
// Microsoft.Office.Interop.Excel.ApplicationClass excelApp = new Microsoft.Office.Interop.Excel.ApplicationClass();
// Microsoft.Office.Interop.Excel.Workbooks wbs = excelApp.Workbooks;
// Microsoft.Office.Interop.Excel.Workbook wb = wbs.Open(filePath, Type.Missing, Type.Missing, Type.Missing, Type.Missing,
// Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing,
// Type.Missing, Type.Missing, Type.Missing, Type.Missing);
// int count = wb.Worksheets.Count;
// string[] names = new string[count];
// for (int i = 1; i <= count; i++)
// {
// names[i - 1] = ((Microsoft.Office.Interop.Excel.Worksheet)wb.Worksheets[i]).Name;
// }
// return names;
//}
#endregion
温馨提示:内容为网友见解,仅供参考
第1个回答  2013-03-01
先读excel模版,根据excel模版中的标识获取winfrom中的数据填入对应的单元格中,然后excel另存为。
这个其实主要就是对excel的操作了,具体对Excel的操作教程网上有很多,随便搜搜都有的。追问

怎么导入excel模版呢?

追答

Excel.Application app = null;

Excel.Workbooks wBook = app.Workbooks;
Excel._Workbook _wBook = wBook.Add(excelModelFilePath);//打开模版文档
Excel.Sheets wSheets = _wBook.Sheets;//获取模版中的所有shees表

excelModelFilePath为模版存放的路径,获取sheet表后,就可以读取sheet表中单元格的内容了。

对excel的操作,注意索引是从1开始的。

看你这个模版挺简单的,你完全可以把winform里面的界面做成这样的,用datagridview控件就行。
然后直接导出到excel,这个还简单一些呀。第一行可以手动添加哈。

本回答被提问者采纳
第2个回答  2013-03-01
到导出的excel的时候写条件,首先合并第0行,并写入“个人信息表”,然后再写一个条件,假如循环到第一行就填写标题 ,第三行开始读取winform中的数据
第3个回答  2013-03-20
建议使用PageOffice,网上有很多示例代码的搜搜看啊。

如何将Winfrom中的数据导入固定的excel模版中C#
if (odr[0].ToString() == "序号")\/\/过滤列头 按你的实际Excel文件 continue;\/\/数据库添加操作 \/*进行非法值的判断 添加数据到数据表中 添加数据时引用事物机制,避免部分数据提交 Add(odr[1].ToString(), odr[2].ToString(), odr[3].ToString());\/\/数据库添加操作,Add方法自己写的 \/...

如何使用c#将winform下excel中内容导入到excel
1、微软的EXCEL插件,(DLL) ,需要运行程序的机器上安装的有对应版本的EXCEL,慢。2、NPOI(第三方),不需要其他约束,二进制处理,极快。两种插件思路都是按照 单元格来处理EXCEL读写,可以自己查询文档,很简单的。比如 var st1 = wk.GetSheetAt(0);\/\/ EXCEL的第一个sheet。var row = st1....

C#winform怎么导出一维码到EXCEL单元格?
在 C# WinForm 中导出一维码到 Excel 单元格可以使用 Microsoft.Office.Interop.Excel 程序集。首先需要将该程序集添加到项目中。首先需要在项目中添加一个引用,如下所示:在项目上右键单击,然后选择“添加引用”。在“添加引用”对话框中,选择“COM”选项卡,然后查找并选择“Microsoft Excel xx.x Ob...

C#,WinForm编程怎么将Textbox里面的内容导出到Excel并保存.
首先放入缓存,接着新建excel文件,定义格式循环写入就可以。

C#winform中如何把表导出到EXCEL
\/\/\/ 将指定的Dataset导出到Excel文件 \/\/\/ \/\/\/ \/\/\/ <returns><\/returns> public bool ExportToExcel(System.Data.DataSet ds, string ReportName){ if (ds.Tables[0].Rows.Count == 0){ MessageBox.Show("数据集为空");} Microsoft.Office.Interop.Excel._Application xlapp = new Applic...

在C#怎么将数据库里的字段绑定到datagridview的固定列名
Winfrom中的DataGridView其实就是一个数组的视图。你的这个要求有两种常见的方式去解决,DataGridView.Name = dg;数据库查询的结果为DataTable dt;1,直接视图绑定:把DataGridView的AutoGenerationColumn 设置为true(自动增加列),然后绑定 dg.DataSource = dt;绑定之后 DataGridView就会根据dt的列来自动...

在C#怎么将数据库里的字段绑定到datagridview的固定列名
1,直接视图绑定:把DataGridView的AutoGenerationColumn 设置为true(自动增加列),然后绑定 dg.DataSource = dt;绑定之后 DataGridView就会根据dt的列来自动显示了。但是如果想更改列头的名称,就需要在查询的时候做好, 比如 select id as '序号',name as '姓名' from xxxx...绑定后,列头就是序...

c# winform程序,如何把读取出来的xml标签转换为excel?
方法一:读取出数据后,以普通TXT文件,或者是HTML表格格式输出至TXT文档后,重新命名为.xls格式 如果以纯文本格式写入的话,数据与数据之间要用制表符隔开。优点速度快,格式控制简单,缺点,非标准EXCEL格式,可以用EXCEL打开,但是后续编辑可能出现问题 方法二:在Winfrom程序运行的本地电脑打开EXCEL程序...

C# winfrom中NPOI操作EXCEL
在Winform中,你需要设计一个界面来实现这些功能,例如两个按钮来触发导入和导出Excel数据的操作,两个标签用来显示操作的耗时,以及一个DataGridView用来显示导入后的数据。要使用NPOI,你需要在项目中进行以下步骤:1. 通过Nuget包管理器添加NPOI引用。2. 搜索并安装NPOI包,确保选择正确的版本。3. 在...

c#winfrom 将datagridview中的数据通过npoi 2.2.0版本导出到excel,可...
你第一行的表头,就可以写成,sheet.AddMergedRegion(new CellRangeAddress(0, 0, 0, 26)); \/\/标示从A1到Z1合并 然后赋值给A1(合并后的单元格是按照起始单元格的坐标来的,)sheet.GetRow(0).GetCell(0).SetCellValue(" XXX统计表");最后设置居中 ICellStyle cellstyle = hssfworkbook.Create...

相似回答