TXT 与 DataTable 互转
//*********************************************************************************************
public static DataTable TXT_To_DataTable(string dirTXT)
{
StreamReader objReader = new StreamReader(dirTXT, Encoding.Default);
DataTable dt = new DataTable();
string strline;
string[] aryline;
bool blnFlag = false;
while ((strline = objReader.ReadLine()) != null)
{
aryline = strline.Split(new char[] { '\t' }, StringSplitOptions.None);
if (blnFlag == false)
{
DataColumn mydc = null;
foreach (string str in aryline)
{
mydc = new DataColumn(str);
dt.Columns.Add(mydc);
}
blnFlag = true;
}
else
{
dt.Rows.Add(aryline);
}
} objReader.Close();
return dt;
}
/// <summary>
/// 以Tab键为间隔,以Tab键表示空值
/// </summary>
/// <param name="dirTXT"></param>
/// <returns></returns>
public static DataTable TXT_To_DataTable2(string dirTXT)
{
StreamReader objReader = new StreamReader(dirTXT, Encoding.Default);
DataTable dt = new DataTable();
string strline;
string[] aryline;
bool blnFlag = false;
while ((strline = objReader.ReadLine()) != null)
{
aryline = strline.Split(new char[] { '\t' }, StringSplitOptions.None);
if (blnFlag == false)
{
foreach (string str in aryline)
{
if (!string.IsNullOrEmpty(str))
{
DataColumn mydc = new DataColumn(str);
dt.Columns.Add(mydc);
}
}
blnFlag = true;
}
else
{
if (aryline.Count() != dt.Columns.Count)
{
strline = Lines_To_Replace(strline);
aryline = strline.Split(new char[] { '\t' }, StringSplitOptions.None);
}
dt.Rows.Add(aryline);
}
}
objReader.Close();
return dt;
}
public static string Lines_To_Replace(string lines)
{
for (int i = ; i < lines.Length; i++)
{
if (i != lines.Length - &&
i > &&
lines.Substring(i - , ) == "\t" &&
lines.Substring(i, ) == "\t" &&
lines.Substring(i + , ) == "\t")
{
//lines.Substring(i, 1) = "\0";
lines = lines.Substring(, i) + "\0" + lines.Substring(i + , lines.Length - i - );
}
}
return lines;
}
/// <summary>
/// 以空格键为间隔,没有空值
/// </summary>
/// <param name="dirTXT"></param>
/// <returns></returns>
public static DataTable TXT_To_DataTable3(string dirTXT)
{
StreamReader objReader = new StreamReader(dirTXT, Encoding.Default);
DataTable dt = new DataTable();
string strline;
bool OK = false;
while ((strline = objReader.ReadLine()) != null)
{
List<string> list = new List<string>();
string tmp = "";
while (strline.Contains(" "))
{
tmp = strline.Substring(, strline.IndexOf(" "));
strline = strline.Substring(strline.IndexOf(" ") + , strline.Length - strline.IndexOf(" ") - ).Trim();
if (!string.IsNullOrEmpty(tmp))
list.Add(tmp);
}
if (!string.IsNullOrEmpty(strline))
list.Add(strline);
if (!OK)
{
foreach (string str in list)
{
if (!string.IsNullOrEmpty(str))
{
DataColumn mydc = new DataColumn(str);
dt.Columns.Add(mydc);
}
}
OK = true;
}
else
dt.Rows.Add(list.ToArray());
}
objReader.Close();
return dt;
} /// <summary>
/// DataTable导出到TXT 以Tab为分隔符,以Tab表示空值
/// </summary>
/// <param name="table"></param>
/// <param name="fullName"></param>
/// <param name="Msg"></param>
/// <returns></returns>
public static bool DataTable_To_TXT2(DataTable table, string fullName, ref string Msg)
{
PathHelper.Check_Directory(fullName);
if (table == null || table.Rows.Count == )
{
Msg += fullName + " 对应的 DataTable 没有数据";
return false;
} FileStream fileStream = new FileStream(fullName, FileMode.Create);
StreamWriter streamWriter = new StreamWriter(fileStream, System.Text.Encoding.UTF8);
StringBuilder strBuilder = new StringBuilder(); for (int j = ; j < table.Columns.Count; j++)
{
string str1 = table.Columns[j].Caption; if (j == table.Columns.Count - )
{
strBuilder.AppendLine(str1);
}
else
{
str1 += "\t";
strBuilder.Append(str1);
}
} for (int i = ; i < table.Rows.Count - ; i++)
{
for (int j = ; j < table.Columns.Count; j++)
{
string str1 = table.Rows[i][j].NullableToString(); if (string.IsNullOrEmpty(str1) || str1 == "\0")
str1 = "\t"; if (j == table.Columns.Count - )
{
strBuilder.AppendLine(str1);
}
else
{
str1 += "\t";
strBuilder.Append(str1);
}
}
} streamWriter.WriteLine(strBuilder.ToString());
streamWriter.Close();
fileStream.Close();
return true;
}
public static bool DataTable_To_TXT(DataTable table, string fullName, ref string Msg)
{
PathHelper.Check_Directory(fullName);
if (table == null || table.Rows.Count == )
{
Msg += fullName + " 对应的 DataTable 没有数据";
return false;
}
int[] iColumnLength = new int[table.Columns.Count];
FileStream fileStream = new FileStream(fullName, FileMode.Create);
StreamWriter streamWriter = new StreamWriter(fileStream, System.Text.Encoding.Unicode);
StringBuilder strBuilder = new StringBuilder(); for (int i = ; i < table.Columns.Count; i++)
{
int iLength = ;
for (int j = ; j < table.Rows.Count; j++)
{
if (iLength < (table.Rows[j][i].ToString()).Length)
{
iLength = (table.Rows[j][i].ToString()).Length;
if ((table.Rows[j][i].ToString()).Length < table.Columns[i].Caption.Length)
{
iLength = table.Columns[i].Caption.Length;
}
} }
iColumnLength[i] = iLength + ;
} for (int j = ; j < table.Columns.Count; j++)
{
string str1 = table.Columns[j].Caption;
int iLength = str1.Length;
int iColumnWidth = iColumnLength[j] + ; for (int k = iLength; k < iColumnWidth; k++)
{
str1 += " ";
} if (j == table.Columns.Count - )
{
strBuilder.AppendLine(str1);
}
else
{
strBuilder.Append(str1);
}
} for (int i = ; i < table.Rows.Count - ; i++)
{
for (int j = ; j < table.Columns.Count; j++)
{
string str1 = table.Rows[i][j].NullableToString();
if (string.IsNullOrEmpty(str1))
str1 = "\0";
int iLength = str1.Length;
int iColumnWidth = iColumnLength[j] + ; for (int k = iLength; k < iColumnWidth; k++)
{
str1 += " ";
}
if (j == table.Columns.Count - )
{
strBuilder.AppendLine(str1);
}
else
{
strBuilder.Append(str1);
}
}
} streamWriter.WriteLine(strBuilder.ToString());
streamWriter.Close();
fileStream.Close();
return true;
}
//****************************************************************************************
TXT 与 DataTable 互转的更多相关文章
- List和DataTable互转
/// <summary> /// List和DataTable互转 /// </summary> static class ListUtility { /// <sum ...
- json datatable互转(真正能用的-原创)
网上有不少的转换类 可是不全 或者有错误 我现在贴一个 js 和C# 互转代码 希望能帮到需要的童鞋 首先C#转成 json /// <summary> /// DataT ...
- C#实现XML与DataTable互转
private string ConvertDataTableToXML(DataTable xmlDS) { MemoryStream stream = null; XmlTextWriter wr ...
- 集合List与DataTable互转
/// <summary> /// 将泛类型集合List类转换成DataTable /// </summary> /// <param name="list&q ...
- C#读取txt文件返回DATATABLE
//1.打开资源管理器 OpenFileDialog open = new OpenFileDialog(); if (open.ShowDialog() == DialogResult.OK) { ...
- DataTable,List,Dictonary互转,筛选及相关写法
1.创建自定义DataTable /// 创建自定义DataTable(一) 根据列名字符串数组, /// </summary> /// <param name="sLi ...
- List实体类、DataTable与xml互转
序列化常用Attribute讲解说明 [XmlRootAttribute("MyCity", Namespace="abc.abc", IsNullable=f ...
- C#调用NPOI组件读取excel表格数据转为datatable写入word表格中并向word中插入图片/文字/书签 获得书签列表
调用word的com组件将400条数据导入word表格中耗时10分钟简直不能忍受,使用NPOI组件耗时4秒钟.但是NPOI中替换书签内容的功能不知道是不支持还是没找到. 辅助类 Excel表格数据与D ...
- DateTable与List<T>相互转换 及JSON与DataTable(DataSet)相互转化
http://www.360doc.com/content/13/0712/09/10504424_299336674.shtml Linq处理List数据 http://blog.163.com/l ...
随机推荐
- 黑暗幽灵(DCM)木马详细分析
黑暗幽灵(DCM)木马详细分析 0x00 背景 只要插上网线或连上WIFI,无需任何操作,不一会儿电脑就被木马感染了,这可能吗?近期,腾讯反病毒实验室拦截到一个“黑暗幽灵”木马的新变种,该木马功能强大 ...
- 【C++】面试题目:从尾到头打印链表
通过<剑指offer 名企面试官精讲典型编程题>看到一道讲解链表的题目. 题目:输入一个链表的头结点,从尾到头反过来打印出每个结点的值 链表定义如下: typedef struct _NO ...
- python动态函数名的研究
所谓动态函数名,就是使用时完全不知道是叫什么名字,可以由用户输入那种. 一般人习惯性会想到eval或exec, 但是众所周知,这样的写法不安全而且容易引起问题,而且不pythonic.而且使用时必须把 ...
- 详解.NET IL代码(一)
本文主要介绍IL代码,内容大部分来自网上,进行整理合并的. 一.IL简介 为什么要了解IL代码? 如果想学好.NET,IL是必须的基础,IL代码是.NET运行的基础,当我们对运行结果有异议的时候,可以 ...
- 001_vagrant利器
一. 这是一个关于Vagrant的学习系列,包含如下文章: Vagrant入门 http://www.cnblogs.com/davenkin/p/vagrant-virtualbox.html 创建 ...
- C# Excel使用NPOI
程序处理excel使用using Microsoft.Office.Interop.Excel方式,运行程序需要电脑安装excel,而且excel版本还需要一样,使用起来不方便.使用NPOI不用电脑安 ...
- centos6.5环境利用scp实现自动化文件备份
centos6.5环境利用scp自动上传备份文件到指定服务器中 需要备份的主机 192.168.3.17 存放备份的主机 192.168.3.18 目的:将3.17主机上/data/storage的文 ...
- visual studio 2017 installer 安装包制作过程出现的问题---无法注册模块 HRESULT -2147024769 请与您的技术支持人员联系
使用visual studio 2017 installer制作打包程序时如果用到了外部控件需要按以下方式操作: 1.将应用程序及应用程序所用到的所有DLL拷贝到打包目录,加入打包程序之中. 2.将应 ...
- oracle进阶之connect by笔记
本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处. http://www.cnblogs.com/king-xg/p/6794562.html 如果觉得对您有帮 ...
- linux压缩与解压
1.tar -zcvf /home/aaa.tar.gz /xahot tar -zcvf 打包后生成的文件名全路径 要打包的目录 解压 #tar -zxvf /usr/local/test.tar. ...