这篇文章给大家分享的是有关C#如何实现的Excel文件操作类的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
具体如下:
using System;
using System.Data;
using System.Data.OleDb;
using System.Text;
using System.IO;
namespace Hxh.API
{
/// <summary>
/// ExcelOpration 的摘要说明。
/// </summary>
public class ExcelOpration
{
OleDbConnection Conn;
string connString ;
string FileName;
public ExcelOpration()
{
//
// TODO: 在此处添加构造函数逻辑
//
}
public ExcelOpration(string _FileName)
{
//
// TODO: 在此处添加构造函数逻辑
//
FileName = _FileName;
}
/// <summary>
/// 打开连接
/// </summary>
private void Open()
{
if(Conn==null)
{
//在此处设置访问的数据库文件
connString = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + FileName +";Extended Properties=Excel 8.0;";
Conn=new OleDbConnection(connString);
Conn.Open();
}
else if(Conn.State==System.Data.ConnectionState.Closed)
Conn.Open();
}
/// <summary>
/// 关闭连接
/// </summary>
public void Close()
{
if (Conn != null)
Conn.Close();
}
/// <summary>
/// 导入数据到Excel
/// </summary>
/// <param name="OutTable"></param>
public void ImportData(DataTable OutTable)
{
CreateExcel(OutTable);
InsertData(OutTable);
}
/// <summary>
/// 创建Excel文件和表头
/// </summary>
private void CreateExcel(DataTable OutTable)
{
StringBuilder sb = new StringBuilder();
if(File.Exists(FileName))
{
File.Delete(FileName);
}
sb.Append("create table Sheet1(");
foreach(DataColumn col in OutTable.Columns)
{
sb.Append(col.ColumnName+" varchar,");
}
sb.Remove(sb.Length-1,1);
sb.Append(")");
Open();
OleDbCommand OleCmd = new OleDbCommand();
OleCmd.Connection = Conn;
OleCmd.CommandText = sb.ToString();
OleCmd.ExecuteNonQuery();
Close();
}
/// <summary>
/// 插入数据
/// </summary>
private void InsertData(DataTable OutTable)
{
OleDbCommand OleCmd = new OleDbCommand();
OleDbParameter[] parm=new OleDbParameter[OutTable.Columns.Count];
StringBuilder sb = new StringBuilder();
sb.Append("insert into Sheet1 values(");
for(int i=0;i<OutTable.Columns.Count;i++)
{
parm=new OleDbParameter("@P"+OutTable.Columns.ColumnName,OleDbType.VarChar);
sb.Append("@P"+OutTable.Columns.ColumnName+",");
OleCmd.Parameters.Add(parm);
}
sb.Remove(sb.Length-1,1);
sb.Append(")");
Open();
OleCmd.Connection = Conn;
OleCmd.CommandText = sb.ToString();
foreach(DataRow row in OutTable.Rows)
{
for(int i=0;i<OutTable.Columns.Count;i++)
{
parm.Value = row[OutTable.Columns.ColumnName].ToString().Trim();
}
OleCmd.ExecuteNonQuery();
}
Close();
}
/// <summary>
/// 从Excel输出数据到数据集
/// </summary>
/// <returns></returns>
public DataSet OutPortData()
{
DataSet ds = new DataSet();
Open();
OleDbDataAdapter myAdapter = new OleDbDataAdapter("select * from [Sheet1$]", Conn);
myAdapter.Fill(ds,"Input");
Close();
return ds;
}
}
}
C#是一个简单、通用、面向对象的编程语言,它由微软Microsoft开发,继承了C和C++强大功能,并且去掉了一些它们的复杂特性,C#综合了VB简单的可视化操作和C++的高运行效率,以其强大的操作能力、优雅的语法风格、创新的语言特性和便捷的面向组件编程从而成为.NET开发的首选语言,但它不适用于编写时间急迫或性能非常高的代码,因为C#缺乏性能极高的应用程序所需要的关键功能。
感谢各位的阅读!关于“C#如何实现的Excel文件操作类”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。