c#分页读取GB文本文件

原文:c#分页读取GB文本文件

应用场景:

a.我在做BI开发测试的时候,有可能面对source文件数GB的情况,如果使用一般的文本编辑器,则会卡死,或要等很久才能显示出来。

b.有时候,我们使用ascii(01)或ascii(02)作为行或列的分隔符,这样的临时文件用于导数据到DB,如果文件导入过程中有错误,需要查看文件 的时候,普通的编辑器不支持换行,则会很恐怖。

为解决这两个需求,我使用c#完成了一个简单的winform的应用程序。

功能列表:

1.根据配置的行数,写测试文件,指定行终止符,列分隔符暂时没有使用上。

2根据指定的行终止符,和pagesize,分页读取文件内容,而且可以在text和byte间转换。

 Sourcecode:

主要的代码如下,使用了一个迭代器:

private IEnumerator<string> ReadLines(string filename)

{

/*

string line;

using (TextReader reader = File.OpenText(filename))

{

while ((line = reader.ReadLine()) != null)

yield return line;

}

*/

StringBuilder sb = new StringBuilder();

using (FileStream fs = File.OpenRead(filename))

{

int b = 0;

while ((b=fs.ReadByte())!=-1)

{

//textbox3 store the row terminator

if (b.ToString() == textBox3.Text.Trim())

{

yield return sb.ToString();

sb.Clear();

}

else

sb.Append(UnicodeEncoding.ASCII.GetString(new byte[] { byte.Parse(b.ToString()) }));

}

}

}

 

   

   

示例截图:

我测试了一次,生成了1个亿的数据行,在系统中显示占用6GB的空间,

我尝试读写,无卡顿情况。

可以进一步更新:

根据列行分隔符显示到gridview中,这样更清晰。

可以从后往前读文件。

   

时间: 2024-11-29 16:57:10

c#分页读取GB文本文件的相关文章

PHP读取txt文本文件并分页显示的方法

 这篇文章主要介绍了PHP读取txt文本文件并分页显示的方法,涉及php操作文件的技巧,具有一定参考借鉴价值,需要的朋友可以参考下     本文实例讲述了PHP读取txt文本文件并分页显示的方法.分享给大家供大家参考.具体实现方法如下:   代码如下: <?php session_start(); if (empty($page)) {$page=1;} if (isset($_GET['page'])==TRUE) {$page=$_GET['page']; } ?> <html>

PHP读取txt文本文件并分页显示的方法_php技巧

本文实例讲述了PHP读取txt文本文件并分页显示的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <?php     session_start();     if (empty($page)) {$page=1;}     if (isset($_GET['page'])==TRUE) {$page=$_GET['page']; } ?> <html> <head> <meta http-equiv="Content-Type&q

使用linq读取分隔符文本文件

 有时我们会处理一些带分隔符数据文本文件.例如,使用","分隔的数据,下面介绍下使用linq读取分隔符文本文件的方法 如下图:   然后它们存储到文本文件有这样的列: 代码如下: First Name Last Name Job Title City Country     在我们读取这个文件之前,先建一个实体类:   代码如下: /// <summary>  /// Customer entity /// </summary> public class Cus

Android提高之SQLite分页读取实现方法_Android

一般来说,Android自身就包含了常用于嵌入式系统的SQLite,这样就免去了开发者自己移植安装的功夫.SQLite 支持多数SQL92标准,很多常用的SQL命令都能在SQLite上面使用,除此之外Android还提供了一系列自定义的方法去简化对SQLite数据库的操作.不过有跨平台需求的程序还是建议使用标准的SQL语句,毕竟这样容易在多个平台之间进行移植. 先来贴出本文程序运行的结果图: 本文实例程序主要讲解了SQLite的基本用法,如:创建数据库,使用SQL命令查询数据表.插入数据,关闭数

.net读取大文本文件高效的方法

问题描述 .net读取大文本文件高效的方法 求教,使用.net读取大文本文件(200M~1G+)并将文本内容存放至数据库的制定table内,我尝试了几种方式要么速度太慢要么报内存溢出,求教高效方法.

c#,textbox怎么能读取大文本文件?

问题描述 c#,textbox怎么能读取大文本文件? 用一个textbox 读取一个3m 的文件但是老是程序无响应······ 怎么才能让textbox读取一个大点的文件. 不禁感激 解决方案 C#读取文本文件C# 读取文本文件c#读取文本文件 解决方案二: 我记得是用富文本编辑控件来读取可以,是数据流好像 解决方案三: 是文本文件的内容放在textbox里边吧.无响应是后台代码的事,跟文本框没关系! 试一下以下代码 string resultTxt="" ; using (FileS

C#快速随机按行读取大型文本文件

原文:C#快速随机按行读取大型文本文件 下面是我实现的一个数据文件随机读取类,可以随机读取大型文本文件的某一行.在我机器上对一个130MB的文本文件,读取第200000的速度从传统做法的400ms提高到了3ms. 一般对文本文件进行读取时,一般采用ReadLine()进行逐行读取.在这种情况下,C#内的FileStream和BufferedStream类处理绰绰有余了.它不会将整个文件全部读入,而是有缓冲的读.但是,要想随机读取某一行,在行数据长度不统一的情况下,如果每次这样遍历到指定行,其效率

Android提高之SQLite分页读取实现方法

一般来说,Android自身就包含了常用于嵌入式系统的SQLite,这样就免去了开发者自己移植安装的功夫.SQLite 支持多数SQL92标准,很多常用的SQL命令都能在SQLite上面使用,除此之外Android还提供了一系列自定义的方法去简化对SQLite数据库的操作.不过有跨平台需求的程序还是建议使用标准的SQL语句,毕竟这样容易在多个平台之间进行移植. 先来贴出本文程序运行的结果图: 本文实例程序主要讲解了SQLite的基本用法,如:创建数据库,使用SQL命令查询数据表.插入数据,关闭数

silverLight 读取服务器端文本文件显示

问题描述 请问下怎么用silverlight4 读取 服务器上的文本文件,然后显示出来下.最好给个demo,完整的代码.谢谢 解决方案 可以的,前提是你的Silverlight应用程序必须以OOB(Out-Of-Browser)的方式运行,且要求提升程序运行的信任级别.http://www.c-sharpcorner.com/uploadfile/dpatra/local-file-access-in-silverlight-4/ 这里有代码