• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C#教程 > C#实现把txt文本数据快速读取到excel中

C#实现把txt文本数据快速读取到excel中

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c#读取文本数据,c#多行文本框,c#文本编辑器,c#文本框,c#代码文本编辑器等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

今天预实现一功能,将txt中的数据转到excel表中,做为matlab的数据源。搜集一些c#操作excel的程序。步骤如下:

下载一个Microsoft.Office.Interop.Excel.dll   在项目中引用。

编写代码如下:

      string path = "c://date//xyu.txt";
      StreamReader sr = new StreamReader(path);
      string strLine = sr.ReadLine();
      int rowNum = 1;
      object missing = System.Reflection.Missing.Value;

      ApplicationClass app = new ApplicationClass();

      app.Application.Workbooks.Add(true);

      Workbook book = (Workbook)app.ActiveWorkbook;
      Worksheet sheet = (Worksheet)book.ActiveSheet;
      while (!string.IsNullOrEmpty(strLine))
      {
        string[] tempArr;
        tempArr = strLine.Split(',');
        for (int k = 1; k <= tempArr.Length; k++)
        {
          sheet.Cells[rowNum, k] = tempArr[k - 1];

        }
        strLine = sr.ReadLine();
        rowNum++;

      }

      //保存excel文件
      book.SaveCopyAs("D://source.xls");
      //关闭文件
      book.Close(false, missing, missing);
      //退出excel
      app.Quit();
      MessageBox.Show("转化成功!");

</div>

  以上代码可以实现功能,由于txt中的数据有60501行,数据量太大。我估算了一下,用以上代码转到excel要用大约2-3分钟。我一共要转9个txt。一共要用20多分钟。这样作出系统显然是让人难以忍受的。接着找资料,发现用rang方法可以提高速率。只用大约3-4秒钟的时间,提高效率几十倍。代码如下:

 string path = "c://date//xyu.txt";
      StreamReader sr = new StreamReader(path);
      string strLine = sr.ReadLine();
      int rowNum = 1;
      object missing = System.Reflection.Missing.Value;

      ApplicationClass app = new ApplicationClass();

      app.Application.Workbooks.Add(true);

      Workbook book = (Workbook)app.ActiveWorkbook;
      Worksheet sheet = (Worksheet)book.ActiveSheet;
      Range r = sheet.get_Range("A1", "C1");

      //获取行数

 
 


      object[,] objectData = new object[65535, 3]; 
      while (!string.IsNullOrEmpty(strLine))
      {
        string[] tempArr;
        tempArr = strLine.Split(',');
        for (int k = 1; k <= tempArr.Length; k++)
        {
          
          objectData[rowNum-1, k-1] = tempArr[k - 1];

        }
        strLine = sr.ReadLine();
        rowNum++;

      }
      r = r.get_Resize(65535, 3);
      r.Value2 = objectData;
      r.EntireColumn.AutoFit();
      //保存excel文件
      book.SaveCopyAs("D://source.xls");
      //关闭文件
      book.Close(false, missing, missing);
      //退出excel
      app.Quit();
      MessageBox.Show("转化成功!");
</div> </div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C#实现把txt文本数据快速读取到excel中
  • c#简单读取文本的实例方法

相关文章

  • 2017-05-28C#值类型和引用类型的深入理解
  • 2017-05-28C#测量程序运行时间及cpu使用时间实例方法
  • 2017-05-28c#数据绑定之数据转化为信息的示例
  • 2017-05-28winform实现关闭按钮失效的两种方法
  • 2017-05-28KMP算法的C#实现方法
  • 2017-05-28基于C#委托的深入分析
  • 2017-05-28解析C#中的常量及如何在C#编程中定义常量
  • 2017-05-28C#基于UDP进行异步通信的方法
  • 2017-05-28C#导入导出Excel数据的两种方法
  • 2017-05-28异步/多线程/任务/并行编程之一:如何选择合适的多线程模型?

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 理解C#中参数的值和引用以及传递结构和类引用的区别
    • 详解C#中的接口属性以及属性访问器的访问限制
    • C#自定义简化cookie类实例
    • c#与mysql的连接
    • C#中using指令的几种用法
    • C#对XML文件的各种操作实现方法
    • C# 定时器定时更新的简单实例
    • C#制作简易的屏保
    • C#实现左截取和右截取字符串实例
    • 在Parallel中使用DbSet.Add()发现的一系列多线程问题和解决思路详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有