功能描述:

  • 集合转换为csv数据
  • DataSe转换为csv数据
    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Linq;
    using System.Text; namespace IM.Common
    {
    /// <summary>
    /// csv操作
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/06/17</para>
    /// </summary>
    public class CsvHelper
    {
    public static string _seperator = ",";
    public static string _bracer = "\"";
    public static string _newline = "\n";
    public static string _regex_special = ".*[,\n\"].*"; /// <summary>
    /// 集合转换为csv数据
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/06/17</para>
    /// </summary>
    /// <param name="list">数据集合,行、列</param>
    /// <returns>csv数据</returns>
    public static string ToCsvData(List<List<string>> list)
    {
    string temp = string.Empty;
    System.Text.StringBuilder sb = new System.Text.StringBuilder();
    foreach (List<string> row in list)
    {
    for (int i = ; i < row.Count; i++)
    {
    temp = row[i];
    temp = (temp != null ? temp : "");
    if (i != )
    {
    sb.Append(_seperator);
    }
    if (temp.Contains(_seperator) || temp.Contains(_bracer) || temp.Contains(_newline))
    {
    if (temp.Contains(_bracer))
    {
    temp = temp.Replace(_bracer, _bracer + _bracer);
    }
    if (temp.Contains(_newline))
    {
    temp = temp.Replace(_newline, "<br/>");
    }
    sb.Append(_bracer + temp + _bracer);
    }
    else
    {
    sb.Append(temp);
    }
    if (i == row.Count - )
    {
    sb.Append(_newline);
    }
    }
    }
    return sb.ToString();
    } /// <summary>
    /// DataSe转换为csv数据
    /// <para>创建作者:changjin</para>
    /// <para>创建日期:2011/06/17</para>
    /// </summary>
    /// <param name="ds">数据集</param>
    /// <returns>csv数据</returns>
    public static string ToCsvData(DataSet ds)
    {
    List<List<string>> list = new List<List<string>>();
    if (ds != null && ds.Tables.Count > && ds.Tables[] != null)
    {
    DataTable dt = ds.Tables[];
    List<string> columnNameList = new List<string>();
    //添加列
    if (dt.Columns.Count > )
    {
    foreach (DataColumn column in dt.Columns)
    {
    columnNameList.Add(column.ColumnName);
    }
    list.Add(columnNameList);
    }
    //迭代添加行记录
    foreach (DataRow row in dt.Rows)
    {
    List<string> rowData = new List<string>();
    foreach (string columnName in columnNameList)
    {
    rowData.Add(Convert.ToString(row[columnName]));
    }
    list.Add(rowData);
    }
    }
    return ToCsvData(list);
    }
    }
    }

csv操作帮助类的更多相关文章

  1. C# csv 操作类

    using System.Data; using System.IO; using System.Text; namespace YanZhiwei.DotNet2.Utilities.Common ...

  2. 一个封装好的CSV文件操作C#类代码

    using System.Data; using System.IO; namespace DotNet.Utilities { /// <summary> /// CSV文件转换类 // ...

  3. 【转载】 C#工具类:Csv文件转换类

    CSV是逗号分隔值格式的文件,其文件以纯文本形式存储表格数据(数字和文本).CSV文件由任意数目的记录组成,记录间以某种换行符分隔:每条记录由字段组成,字段间的分隔符是其它字符或字符串,最常见的是逗号 ...

  4. XML格式示例 与 XML操作(读取)类封装

    header('Content-Type: text/xml'); <?xml version="1.0" encoding="utf-8" standa ...

  5. Java CSV操作(导出和导入)

    Java CSV操作(导出和导入)  CSV是逗号分隔文件(Comma Separated Values)的首字母英文缩写,是一种用来存储数据的纯文本格式,通常用于电子表格或数据库软件.在 CSV文件 ...

  6. 简洁的PHP操作SQLite类

    SQLite是一款轻型的数据库,是遵守ACID的关联式数据库管理系统,它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了. ...

  7. C#工具类:Json操作帮助类(转载)

    原文转载自C#工具类:Json操作帮助类_IT技术小趣屋. Json序列化和反序列化在程序开发中时常会遇到,在C#中可以使用很多种方法实现对数据的Json序列化和反序列化,封装一个Json操作工具类来 ...

  8. 【转载】C#工具类:Json操作帮助类

    Json序列化和反序列化在程序开发中时常会遇到,在C#中可以使用很多种方法实现对数据的Json序列化和反序列化,封装一个Json操作工具类来简化相应的操作,该工具类中包含以下功能:对象转JSON.数据 ...

  9. 【转载】微软官方提供的Sqlserver数据库操作帮助类SQLHelper类

    在.NET平台中,C#语言一般使用ADO.NET组件来操作Sqlserver数据库,通过ADO.NET组件可以实现连接数据库.查询数据集.执行SQL语句以及关闭数据库连接等操作,为此网上有很多开发者自 ...

随机推荐

  1. http请求的cookie

    Cookie的作用: Cookie是用于维持服务端会话状态的,通常由服务端写入,在后续请求中,供服务端读取. HTTP请求,Cookie的使用过程 1.server通过HTTP Response中的& ...

  2. 《编写高质量代码--Web前端开发修炼之道》读书笔记

    前言 这两周参加公司的新项目,采用封闭式开发(项目成员在会议室里开发),晚上加班到很晚,所以没时间和精力写原创博客了,今天就分享下这篇<编写高质量代码--Web前端开发修炼之道>读书笔记吧 ...

  3. Hive学习之五 《Hive进阶—UDF操作案例》 详解

    hive—UDF操作 udf的操作过程: 在HIVE会话中add 自定义函数的jar文件,然后创建function,继而使用函数. 下面就以下面课题为例: 课题:统计每个活动的PV和UV 一.Java ...

  4. 优化HTTP前端请求构建高性能ASP.NET站点

    HTTP请求的优化  在一个网页的请求过程中,其实整个页面的html结构(就是页面的那些html骨架)请求的时间是很短的,一般是占整个页面的请求时间的10%-20%.在页面加载的其余的时间实际上就是在 ...

  5. 解决Mac上Android开发时adb连接不到手机问题

    今天在Mac OS上进行Android开发的时候,打开eclipse连接不到手机MX4问题 1. 插入手机打开 Terminal,输入 system_profiler  SPUSBDataType 2 ...

  6. 在ubuntu14.04上安装oracle java6 java7的方法

    注意: Debian建议安装openjdk,在release包中已包含. oracle的java需要自己安装,安装步骤如下: 1. 首先安装java-package,安装方法:apt-get inst ...

  7. js 求两个日期之间相差天数

    //求两个日期之间的相差天数 function daysBetween(DateOne, DateTwo) { var OneMonth = DateOne.substring(5, DateOne. ...

  8. C程序设计语言练习题1-23

    练习1-23 编写一个删除C语言程序中所有的注释语句.要正确处理带引号的字符串与字符常量.在C语言中,注释不能嵌套. 代码如下: #include <stdio.h> // 包含标准库的信 ...

  9. C语言 位操作

    c语言位操作中需要注意有: 位操作只针对整型和字符型数据 在右移操作中:对无符号数和有符号中的正数补 0:符号数中的负数,取决于所使用的系统:补 0 的称为“逻辑右移”,补 1 的称为“算术右移”. ...

  10. 10:Hello, World!的大小

    总时间限制:  1000ms 内存限制:  65536kB 描述 还记得在上一章里,我们曾经输出过的“Hello, World!”吗? 它虽然不是本章所涉及的基本数据类型的数据,但我们同样可以用siz ...