热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

c#中Excel数据的导入、导出

**导出到Excel文件含完整路径含字段标题
ExpandedBlockStart.gifContractedBlock.gif/**//// 
InBlock.gif
/// 导出到 Excel 文件
InBlock.gif
/// 

InBlock.gif
/// 含完整路径
ExpandedBlockEnd.gif
/// 含字段标题名

None.gifpublic void ExpExcel(string fileName ,DataTable dataTable)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
InBlock.gif    Excel.ApplicationClass apc 
=new Excel.ApplicationClass();
InBlock.gif
InBlock.gif    apc.Visible 
= false ;
InBlock.gif    Excel.Workbook wkbook 
= apc.Workbooks.Add( true ) ;
InBlock.gif    Excel.Worksheet wksheet 
= (Excel.Worksheet)wkbook.ActiveSheet;
InBlock.gif
InBlock.gif    
int rowIndex = 2;
InBlock.gif    
int colIndex = 1;
InBlock.gif
InBlock.gif    wksheet.get_Range(apc.Cells[
1,1],apc.Cells[dataTable.Rows.Count,dataTable.Columns.Count]).NumberFormat = "@";
InBlock.gif
InBlock.gif    
//取得列标题
InBlock.gif
    foreach (DataColumn dc in dataTable.Columns)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        colIndex 
++;
InBlock.gif        wksheet.Cells[
1,colIndex] = dc.ColumnName;
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
//取得表格中数据
InBlock.gif
    foreach (DataRow dr in dataTable.Rows)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        colIndex 
= 1;
InBlock.gif        
foreach (DataColumn dc in dataTable.Columns)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
if(dc.DataType == System.Type.GetType("System.DateTime"))
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                apc.Cells[rowIndex,colIndex] 
= "'"+(Convert.ToDateTime(dr[dc.ColumnName].ToString())).ToString("yyyy-MM-dd");
ExpandedSubBlockEnd.gif            }

InBlock.gif            
else
InBlock.gif                
if(dc.DataType == System.Type.GetType("System.String"))
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                apc.Cells[rowIndex,colIndex] 
= "'"+dr[dc.ColumnName].ToString();
ExpandedSubBlockEnd.gif            }

InBlock.gif            
else
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                apc.Cells[rowIndex,colIndex] 
= "'"+dr[dc.ColumnName].ToString();
ExpandedSubBlockEnd.gif            }

InBlock.gif
InBlock.gif            wksheet.get_Range(apc.Cells[rowIndex,colIndex],apc.Cells[rowIndex,colIndex]).HorizontalAlignment 
= Excel.XlHAlign.xlHAlignLeft;
InBlock.gif
InBlock.gif            colIndex
++;
ExpandedSubBlockEnd.gif        }

InBlock.gif        rowIndex
++;
ExpandedSubBlockEnd.gif    }

InBlock.gif    
InBlock.gif    
//设置表格样式
InBlock.gif
    wksheet.get_Range(apc.Cells[1,1],apc.Cells[1,dataTable.Columns.Count]).Interior.ColorIndex = 20
InBlock.gif    wksheet.get_Range(apc.Cells[
1,1],apc.Cells[1,dataTable.Columns.Count]).Font.ColorIndex = 3;
InBlock.gif    wksheet.get_Range(apc.Cells[
1,1],apc.Cells[1,dataTable.Columns.Count]).Borders.Weight = Excel.XlBorderWeight.xlThin;
InBlock.gif    wksheet.get_Range(apc.Cells[
1,1],apc.Cells[dataTable.Rows.Count,dataTable.Columns.Count]).Columns.AutoFit();
InBlock.gif
InBlock.gif    
if(File.Exists(fileName))
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        File.Delete(fileName);
ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    wkbook.SaveAs( fileName ,Type.Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing, Excel.XlSaveAsAccessMode.xlNoChange ,Type.Missing,Type.Missing,Type.Missing,Type.Missing,Type.Missing);
InBlock.gif   
InBlock.gif    wkbook.Close(Type.Missing,Type.Missing,Type.Missing);
InBlock.gif    apc.Quit();
InBlock.gif    wkbook 
= null;
InBlock.gif    apc 
= null;
InBlock.gif    GC.Collect();
ExpandedBlockEnd.gif}

ExpandedBlockStart.gifContractedBlock.gif
/**//// 
InBlock.gif
/// 从Excel导入帐户(逐单元格读取)
InBlock.gif
/// 

ExpandedBlockEnd.gif
/// 完整路径名

None.gifpublic IList ImpExcel(string fileName)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
InBlock.gif    IList alExcel 
= new ArrayList();
InBlock.gif    UserInfo userInfo 
= new UserInfo();
InBlock.gif
InBlock.gif    Excel.Application app;
InBlock.gif    Excel.Workbooks wbs;
InBlock.gif    Excel.Worksheet ws;
InBlock.gif
InBlock.gif    app 
= new Excel.Application();
InBlock.gif    wbs 
= app.Workbooks;
InBlock.gif    wbs.Add(fileName);
InBlock.gif    ws
= (Excel.Worksheet)app.Worksheets.get_Item(1);
InBlock.gif    
int a = ws.Rows.Count;
InBlock.gif    
int b = ws.Columns.Count;
InBlock.gif    
InBlock.gif    
for ( int i &#61; 2; i < 4; i&#43;&#43;)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
for ( int j &#61; 1; j < 21; j&#43;&#43;)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            Excel.Range range 
&#61; ws.get_Range(app.Cells[i,j],app.Cells[i,j]);
InBlock.gif            range.Select();
InBlock.gif            alExcel.Add( app.ActiveCell.Text.ToString() );
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif    }

InBlock.gif
InBlock.gif    
return alExcel;
ExpandedBlockEnd.gif}

None.gif
None.gif
ExpandedBlockStart.gifContractedBlock.gif
/**//// 
InBlock.gif
/// 从Excel导入帐户(新建oleDb连接,Excel整表读取,适于无合并单元格时)
InBlock.gif
/// 

InBlock.gif
/// 完整路径名
ExpandedBlockEnd.gif
/// 

None.gifpublic DataTable ImpExcelDt (string fileName)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
InBlock.gif    
string strCon &#61; " Provider &#61; Microsoft.Jet.OLEDB.4.0 ; Data Source &#61; " &#43; fileName &#43; ";Extended Properties&#61;Excel 8.0" ;
InBlock.gif    OleDbConnection myConn 
&#61; new OleDbConnection ( strCon ) ;
InBlock.gif    
string strCom &#61; " SELECT * FROM [Sheet1$] " ;
InBlock.gif    myConn.Open ( ) ;
InBlock.gif    OleDbDataAdapter myCommand 
&#61; new OleDbDataAdapter ( strCom , myConn ) ;
InBlock.gif    DataSet myDataSet 
&#61; new DataSet ( ) ;
InBlock.gif    myCommand.Fill ( myDataSet , 
"[Sheet1$]" ) ;
InBlock.gif    myConn.Close ( ) ;
InBlock.gif
InBlock.gif    DataTable dtUsers 
&#61; myDataSet.Tables[0];
InBlock.gif
InBlock.gif    
return dtUsers;
ExpandedBlockEnd.gif}

None.gif
None.gif
None.gifdataGrid中显示&#xff1a;
None.gifDataGrid1.DataMember
&#61; "[Sheet1$]" ;
None.gifDataGrid1.DataSource 
&#61; myDataSet ;

转载于:https://www.cnblogs.com/liuzhixian/articles/851983.html


推荐阅读
  • 在C#和ASP.NET开发中,TypeParse 是一个非常实用的类型解析扩展方法库,提供了简便的类型转换功能。例如,通过 `var int1 = "12".TryToInt();` 可以将字符串安全地转换为整数,如果转换失败则返回0。此外,还支持更多复杂的类型转换场景,如 `var int2 = "22x".TryToInt();` 和 `var int3 = "3.14".TryToInt();`,确保了代码的健壮性和易用性。 ... [详细]
  • 在Android应用开发中,实现与MySQL数据库的连接是一项重要的技术任务。本文详细介绍了Android连接MySQL数据库的操作流程和技术要点。首先,Android平台提供了SQLiteOpenHelper类作为数据库辅助工具,用于创建或打开数据库。开发者可以通过继承并扩展该类,实现对数据库的初始化和版本管理。此外,文章还探讨了使用第三方库如Retrofit或Volley进行网络请求,以及如何通过JSON格式交换数据,确保与MySQL服务器的高效通信。 ... [详细]
  • 分享一款基于Java开发的经典贪吃蛇游戏实现
    本文介绍了一款使用Java语言开发的经典贪吃蛇游戏的实现。游戏主要由两个核心类组成:`GameFrame` 和 `GamePanel`。`GameFrame` 类负责设置游戏窗口的标题、关闭按钮以及是否允许调整窗口大小,并初始化数据模型以支持绘制操作。`GamePanel` 类则负责管理游戏中的蛇和苹果的逻辑与渲染,确保游戏的流畅运行和良好的用户体验。 ... [详细]
  • 本指南介绍了 `requests` 库的基本使用方法,详细解释了其七个主要函数。其中,`requests.request()` 是构建请求的基础方法,支持其他高级功能的实现。此外,我们还重点介绍了如何使用 `requests.get()` 方法来获取 HTML 网页内容,这是进行网页数据抓取和解析的重要步骤。通过这些基础方法,读者可以轻松上手并掌握网页数据抓取的核心技巧。 ... [详细]
  • 枚举类中enum关键字的常见应用与实践
    在枚举类中,`enum`关键字具有重要的作用,本文探讨了其常见的应用场景与实践。特别指出,枚举对象必须置于枚举类的首行,否则将导致编译错误。通过具体的代码示例,详细解析了这一规则及其背后的原理,帮助开发者更好地理解和使用枚举类。 ... [详细]
  • 本文探讨了 Kafka 集群的高效部署与优化策略。首先介绍了 Kafka 的下载与安装步骤,包括从官方网站获取最新版本的压缩包并进行解压。随后详细讨论了集群配置的最佳实践,涵盖节点选择、网络优化和性能调优等方面,旨在提升系统的稳定性和处理能力。此外,还提供了常见的故障排查方法和监控方案,帮助运维人员更好地管理和维护 Kafka 集群。 ... [详细]
  • 本文探讨了 Java 中 Pair 类的历史与现状。虽然 Java 标准库中没有内置的 Pair 类,但社区和第三方库提供了多种实现方式,如 Apache Commons 的 Pair 类和 JavaFX 的 javafx.util.Pair 类。这些实现为需要处理成对数据的开发者提供了便利。此外,文章还讨论了为何标准库未包含 Pair 类的原因,以及在现代 Java 开发中使用 Pair 类的最佳实践。 ... [详细]
  • 本文详细介绍了在C#编程环境中绘制正方形图像的技术和实现方法,通过具体示例代码帮助读者理解和掌握相关技巧。内容涵盖从基础概念到实际应用的各个方面,适合初学者和有一定经验的开发者参考。希望对您的C#学习之旅有所帮助,并激发您进一步探索的兴趣。 ... [详细]
  • 动态壁纸 LiveWallPaper:让您的桌面栩栩如生(第二篇)
    在本文中,我们将继续探讨如何开发动态壁纸 LiveWallPaper,使您的桌面更加生动有趣。作为 2010 年 Google 暑期大学生博客分享大赛 Android 篇的一部分,我们将详细介绍 Ed Burnette 的《Hello, Android》第三版中的相关内容,并分享一些实用的开发技巧和经验。通过本篇文章,您将了解到如何利用 Android SDK 创建引人入胜的动态壁纸,提升用户体验。 ... [详细]
  • 深入解析 Java UTC 时间处理技术与应用 ... [详细]
  • 本文介绍了一种利用Dom4j库和JFileChooser组件在Java中实现XML文件自定义路径导出的方法。通过创建一个Document对象并设置根元素,结合JFileChooser选择目标路径,实现了灵活的XML文件导出功能。具体步骤包括初始化Document对象、构建XML结构以及使用JFileChooser选择保存路径,确保用户能够方便地将生成的XML文件保存到指定位置。 ... [详细]
  • Java 零基础入门:SQL Server 学习笔记(第21篇)
    Java 零基础入门:SQL Server 学习笔记(第21篇) ... [详细]
  • MySQL 数据操作:增、删、查、改全面解析
    MySQL 数据操作:增、删、查、改全面解析 ... [详细]
  • 如何构建和部署C# Windows服务应用程序
    本文介绍了如何从零开始构建和部署C# Windows服务应用程序。通过详细步骤和代码示例,帮助读者掌握创建、配置和部署Windows服务的关键技术点,适合初学者和有经验的开发人员参考。 ... [详细]
  • 探讨 jBPM 数据库表结构设计的精要与实践
    探讨 jBPM 数据库表结构设计的精要与实践 ... [详细]
author-avatar
c6643e7f36_253
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有