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 ...
随机推荐
- centos7入门
yum install net-tools 设置IP和掩码 ifconfig eth0 1.1.1.20 netmask 255.255.255.0 设置网关 route add default gw ...
- python cookbook 笔记二
去重和排序: #coding=utf-8 def dedupe(items): seen = set() for item in items: if item not in seen: yield i ...
- TabCtrl使用
TabCtrl使用 0x1 新建子页面 插入三个对话框,ID分别为:IDD_PAGE_FILE.IDD_PAGE_NETWORK.IDD_PAGE_PROCESS 工具箱-[属性]-[Style]设置 ...
- MySQL基于LVM快照的备份恢复(临时)
目录1.数据库全备份2.准备LVM卷3.数据恢复到LVM卷4.基于LVM快照备份数据5.数据灾难恢复6.总结 写在前面:测试环境中已安装有mysql 5.5.36数据库,但数据目录没有存放在LVM卷, ...
- C++:vector中的v.at(0)和v[0]的区别
设v是一个vector的对象, 如果v是非空的,则v.at(0)和v[0]是没有区别的,都是取数组中第一个值: 如果v是空的,则v.at(0)会抛出异常(exception std::out_of_r ...
- javaScript中自定义sort中的比较函数,用于比较字符串长度,数值大小
, 1.2, 'bb', 'cc']; var len = arr.length; // for (var i = 0; i < len; i++) { // alert(arr + &qu ...
- openwrt git 代码下载地址
openwrt 各个版本代码下载 trunk:git clone git://github.com/openwrt/openwrt.git 15.05 (Chaos Calmer)git clone ...
- jquery之data()
$("#test").data("myProp","123") alert($("#test").data(" ...
- Sudo的用法和Visudo设置
身为程序员,你可以活在一个没有Windows的世界,当你离不开Unix(Linux,Mac...).而在Unix下面,你离不开terminal,离不开sudo. 你知道sudo command,然后输 ...
- 【ES】学习5-全文搜索
全文搜索两个最重要的方面是:相关性, 分析. 一旦谈论相关性或分析这两个方面的问题时,我们所处的语境是关于查询的而不是过滤. match:单个词查询 GET /my_index/my_type/_se ...