DataTable到string   

/// <summary>         /// DataTable 到 string         /// </summary>         /// <param name="dt"></param>         /// <returns></returns>         public static string DataTableToString(DataTable dt)         {             //!@&,#$%,^&*为字段的拼接字符串             //为了防止连接字符串不在DataTable数据中存在,特意将拼接字符串写成特殊的字符!             StringBuilder strData = new StringBuilder();             StringWriter sw = new StringWriter();

//DataTable 的当前数据结构以 XML 架构形式写入指定的流             dt.WriteXmlSchema(sw);             strData.Append(sw.ToString());             sw.Close();             strData.Append("@&@");             for (int i = 0; i < dt.Rows.Count; i++)           //遍历dt的行             {                 DataRow row = dt.Rows[i];                 if (i > 0)                                    //从第二行数据开始,加上行的连接字符串                 {                     strData.Append("#$%");                 }                 for (int j = 0; j < dt.Columns.Count; j++)    //遍历row的列                 { if (j > 0) //从第二个字段开始,加上字段的连接字符串                     {                         strData.Append("^&*");                     }                     strData.Append(Convert.ToString(row[j])); //取数据                 }             }

return strData.ToString();         }

string到DataTable

       /// <summary>         /// string 到 DataTable         /// </summary>         /// <param name="strdata"></param>         /// <returns></returns>         public static DataTable StringToDataTable(string strdata)         {             if (string.IsNullOrEmpty(strdata))             {                 return null;             }             DataTable dt = new DataTable();             string[] strSplit = { "@&@" };             string[] strRow = { "#$%" };    //分解行的字符串             string[] strColumn = { "^&*" }; //分解字段的字符串

string[] strArr = strdata.Split(strSplit, StringSplitOptions.None);             StringReader sr = new StringReader(strArr[0]);             dt.ReadXmlSchema(sr);             sr.Close();

string strTable = strArr[1]; //取表的数据             if (!string.IsNullOrEmpty(strTable))             {                 string[] strRows = strTable.Split(strRow, StringSplitOptions.None); //解析成行的字符串数组                 for (int rowIndex = 0; rowIndex < strRows.Length; rowIndex++)       //行的字符串数组遍历                 {                     string vsRow = strRows[rowIndex]; //取行的字符串                     string[] vsColumns = vsRow.Split(strColumn, StringSplitOptions.None); //解析成字段数组                     dt.Rows.Add(vsColumns);                 }             }             return dt;         }

datatabe 与string的更多相关文章

  1. DataTable to byte[]、DataTable to XML(string)

    DataTabe 对象在很多地方都会用到,特别是在Web Service.Socket等需网络传输的地方. 但是在有些地方,如果直接传递的话,程序可能会报告DataTable无法序列化错误. 解决问题 ...

  2. 透过WinDBG的视角看String

    摘要 : 最近在博客园里面看到有人在讨论 C# String的一些特性. 大部分情况下是从CODING的角度来讨论String. 本人觉得非常好奇, 在运行时态, String是如何与这些特性联系上的 ...

  3. JavaScript String对象

    本编主要介绍String 字符串对象. 目录 1. 介绍:阐述 String 对象的说明以及定义方式. 2. 实例属性:介绍 String 对象的实例属性: length. 3. 实例方法:介绍 St ...

  4. ElasticSearch 5学习(9)——映射和分析(string类型废弃)

    在ElasticSearch中,存入文档的内容类似于传统数据每个字段一样,都会有一个指定的属性,为了能够把日期字段处理成日期,把数字字段处理成数字,把字符串字段处理成字符串值,Elasticsearc ...

  5. [C#] string 与 String,大 S 与小 S 之间没有什么不可言说的秘密

    string 与 String,大 S 与小 S 之间没有什么不可言说的秘密 目录 小写 string 与大写 String 声明与初始化 string string 的不可变性 正则 string ...

  6. js报错: Uncaught RangeError: Invalid string length

    在ajax请求后得到的json数据,遍历的时候chrome控制台报这个错误:Uncaught RangeError: Invalid string length,在stackoverflow查找答案时 ...

  7. c# 字符串连接使用“+”和string.format格式化两种方式

    参考文章:http://www.liangshunet.com/ca/201303/218815742.htm 字符串之间的连接常用的两种是:“+”连接.string.format格式化连接.Stri ...

  8. 【手记】注意BinaryWriter写string的小坑——会在string前加上长度前缀length-prefixed

    之前以为BinaryWriter写string会严格按构造时指定的编码(不指定则是无BOM的UTF8)写入string的二进制,如下面的代码: //将字符串"a"写入流,再拿到流的 ...

  9. JavaScript中String对象的方法介绍

    1.字符方法 1.1 charAt() 方法,返回字符串中指定位置的字符. var question = "Do you like JavaScript?"; alert(ques ...

随机推荐

  1. 2018-2019-2 《网络对抗技术》Exp0 Kali安装 Week1 20165211

    目录 软件和镜像下载 虚拟机软件 Kali系统的下载 Kali系统安装 网络配置 设置共享文件夹和剪切板 安装VMware增强工具 设置共享文件夹 设置共享剪切板 更新软件源 软件和镜像下载 虚拟机软 ...

  2. NOIP模拟题 2017.11.6

    题目大意 给定一个大小为n的数组,从中选出一个子集使得这个子集中的数的和能被n整除. 假设开始我没有做出来,那么我就random_shuffle一下,然后计算前缀和,有一个能被n整除,就输出答案.于是 ...

  3. Python3 tkinter基础 Entry state 不可写 不可选 不可复制的输入框

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  4. Flask学习【第11篇】:整合Flask中的一些知识点

    SQLAlchemy-Utils 由于sqlalchemy中没有提供choice方法,所以借助SQLAlchemy-Utils组件提供的choice方法 import datetime from sq ...

  5. Web Service平台有三种元素构成:SOAP、WSDL、UDDI。区别和联系

    Web Service平台有三种元素构成:SOAP.WSDL.UDDI.一个消费者可以在UDDI注册表查找服务,取得服务的WSDL描述,然后通过SOAP来调用服务.SOAP.WSDL.UDDI的区别如 ...

  6. centos6.8下源码编译安装tmux

    1. 获取源码 git clone https://github.com/tmux/tmux.git ~/tmux 2. 准备工作 2.1 安装ncurses开发库 yum install ncurs ...

  7. 配置vim

    VundleVuldle是一个全自动的插件管理器,让我们通过维护插件列表的方式管理插件.它为安装.更新.删除插件提供了方便的命令.在安装Git的情况下(本文不赘述Git的安装),输入命令: git c ...

  8. 【教程】Git在Eclipse中的安装和基本使用

    一.安装 点击 Help->Install New Software->add 安装地址为:http://download.eclipse.org/egit/updates/ 选择插件   ...

  9. nginx重新编译添加ssl模块

    https://www.cnblogs.com/zhming26/p/6278667.html https nginx配置 找到安装nginx的源码根目录,如果没有的话下载新的源码 http://ng ...

  10. Collection与Collections的区别

    Collection是集合类的上级接口,继承与他有关的接口主要有List和Set Collections是针对集合类的一个帮助类,他提供一系列静态方法实现对各种集合的搜索.排序.线程安全等操作 稍微举 ...