资源简介
完美解决C#在解析csv时,把字符串当做小数处理问题;
直接使用,传入绝对路径即可
代码片段和文件信息
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using System.IO;
using System.Text.Regularexpressions;
namespace _3GAlarm_Test
{
class CSVProvider
{
///
/// 将CSV数据转换为DataTable
///
/// csv文件路径
/// 是否将第一行作为字段名
///
public static DataTable ToDataTable2(string csvFilePath bool isRowHead)
{
DataTable dt = null;
if (File.Exists(csvFilePath))
{
string csvstr = File.ReadAllText(csvFilePath Encoding.Default);
if (!string.IsNullOrEmpty(csvstr))
{
dt = ToDataTable(csvstr isRowHead);
}
}
return dt;
}
///
/// 将CSV数据转换为DataTable
///
/// 包含以““分隔的CSV数据的字符串
/// 是否将第一行作为字段名
///
public static DataTable ToDataTable(string csv bool isRowHead)
{
DataTable dt = null;
if (!string.IsNullOrEmpty(csv))
{
dt = new DataTable();
string[] csvRows = csv.Split(new string[] { Environment.NewLine } StringSplitOptions.RemoveEmptyEntries);
string[] csvColumns = null;
if (csvRows != null)
{
if (csvRows.Length > 0)
{
//第一行作为字段名添加第一行记录并删除csvRows中的第一行数据
if (isRowHead)
{
csvColumns = FromCsvLine(csvRows[0]);
csvRows[0] = null;
for (int i = 0; i < csvColumns.Length; i++)
{
dt.Columns.Add(csvColumns[i]);
}
}
for (int i = 0; i < csvRows.Length; i++)
{
if (csvRows[i] != null)
{
csvColumns = FromCsvLine(csvRows[i]);
//检查列数是否足够不足则补充
if (dt.Columns.Count < csvColumns.Length)
{
int columnCount = csvColumns.Length - dt.Columns.Count;
for (int c = 0; c < columnCount; c++)
{
dt.Columns.Add();
}
}
dt.Rows.Add(csvColumns);
}
}
- 上一篇:C# 蓝牙 文件传输 DEMO
- 下一篇:ZedGraph控件使用方法例程
相关资源
- C#解析HL7消息的库135797
- C# OCR数字识别实例,采用TessnetOcr,对
- 考试管理系统 - C#源码
- asp.net C#购物车源代码
- C#实时网络流量监听源码
- C#百度地图源码
- Visual C#.2010从入门到精通配套源程序
- C# 软件版本更新
- C#屏幕软键盘源码,可以自己定制界面
- 智慧城市 智能家居 C# 源代码
- c#获取mobile手机的IMEI和IMSI
- C#实现简单QQ聊天程序
- 操作系统 模拟的 欢迎下载 C#版
- C#写的计算机性能监控程序
- 用C#实现邮件发送,有点类似于outlo
- MVC model层代码生成器 C#
- c#小型图书销售系统
- C# Socket Server Client 通讯应用 完整的服
- c# winform 自动登录 百度账户 源代码
- C#编写的16进制计算器
- C#TCP通信协议
- C# 数据表(Dataset)操作 合并 查询一
- C#语音识别系统speechsdk51,SpeechSDK51L
- 数据库备份还原工具1.0 C# 源码
-
[免费]xm
lDocument 节点遍历C# - EQ2008LEDc#开发实例
- DirectX.Capturec# winform 操作摄像头录像附
- c# 实现的最大最小距离方法对鸢尾花
- C#版保龄球记分代码
- C#自定义控件
评论
共有 条评论