.NET中如何将文本文件的内容存储到DataSet

 更新时间:2021年9月22日 10:05  点击:1887

前言

项目中对文本文件的操作比较简单,但是如果需要将文本文件的内容写入系统的缓存中,操作起来,会稍微的繁琐一些。现在总结一个较为通用的方法,将文本文件的内容缓存进入DataSet数据集中。下面话不多说了,我们直接来看示例代码吧。

示例代码

  private DataSet _iifSet;

  /// <summary>
  /// 将文本文件转化为DataSet
  /// </summary>
  /// <param name="filePath"></param>
  /// <returns></returns>
  public DataSet Parse(string filePath)
  {
        if (string.IsNullOrEmpty(filePath))
        {
          throw new ArgumentNullException(filePath);
        }

try
   {
    _iifSet = new DataSet();
    var fileText = System.IO.File.ReadAllText(filePath);
    var lines = fileText.Split('\n');
    CreateTables(lines, _iifSet);
    FillSet(lines, _iifSet);
    return _iifSet;
   }
   catch (IOException ex)
   {
    throw new IOException(ex.Message);
   }
   
  }

  /// <summary>
  /// 读取行数组并将其解析为数据集的表
  /// </summary>
  /// <param name="lines">String iif文件中的行数组</param>
  /// <param name="set"></param>
  private void FillSet(IReadOnlyList<string> lines, DataSet set)
  {
   for (var i = 0; i < lines.Count; i++)
   {
    if (IsTableHeader(lines[i]))
    {
     continue;
    }
    if (lines[i] == "" || lines[i] == "\r" || lines[i] == "\n\r" || lines[i] == "\n")
    {
     continue;
    }
    if (lines[i].IndexOf(";__IMPORTED__", StringComparison.Ordinal) != -1)
    {
     continue;
    }
    var line = lines[i];
    while (!IsFullLine(line, set))
    {
     i++;
     line += lines[i];
    }
    ParseRecord(line, set);
   }
  }

  /// <summary>
  /// 解析记录
  /// </summary>
  /// <param name="line"></param>
  /// <param name="set"></param>
  private void ParseRecord(string line, DataSet set)
  {
   if (IsTableHeader(line))
   {
    return;
   }
   var tablename = line.Split('\t')[0];
   var parameters = CreateDataRowParams(line, set.Tables[tablename].Columns.Count);
   if (parameters.Length > 0)
    set.Tables[tablename].Rows.Add(parameters);
  }

  private bool IsFullLine(string line, DataSet set)
  {
   if (IsTableHeader(line))
   {
    return true;
   }
   var values = line.Split('\t').Length;
   var tableName = line.Split('\t')[0];
   var columns = set.Tables[tableName].Columns.Count;
   return values >= columns;
  }

  private bool IsTableHeader(string tab)
  {
   return tab.StartsWith("!");
  }


  /// <summary>
  /// 创建datatable
  /// </summary>
  /// <param name="lines"></param>
  /// <param name="set"></param>
  private void CreateTables(IReadOnlyList<string> lines, DataSet set)
  {
   foreach (var t in lines.Where(IsTableHeader))
   {
    set.Tables.Add(CreateTable(t));
   }
  }


  private DataTable CreateTable(string line)
  {
   var values = line.Split('\t');
   values[0] = values[0].Substring(1);
   var dt = new DataTable(values[0]);
   values[0] = null;
   foreach (var name in values)
   {
    if (string.IsNullOrEmpty(name))
     continue;
    var dc = new DataColumn(name, typeof(string));
    try
    {
     dt.Columns.Add(dc);
    }
    catch (DuplicateNameException)
    {
     dc = new DataColumn(name + "_duplicateCol" + dt.Columns.Count);
     dt.Columns.Add(dc);
    }
   }

   return dt;
  }

  public string GetTableName(string line)
  {
   var values = line.Split('\t');
   if (values[0].StartsWith("!"))
   {
    values[0] = values[0].Substring(1);
   }
   return values[0];
  }

  public readonly static object[] EmptyStringArray = { };

  private object[] CreateDataRowParams(string line, int maxLength)
  {
   var raw = line.Split('\t');
   var length = raw.Length - 1;
   if (length == 0 || maxLength == 0)
    return EmptyStringArray;
   if (length > maxLength)
    length = maxLength;
   var values = new string[length];
   for (var i = 0; i < length; i++)
   {
    values[i] = raw[i + 1];
   }

   if (values[values.Length - 1].EndsWith("\n"))
   {
    values[values.Length - 1] = values[values.Length - 1].Substring(0, values[values.Length - 1].LastIndexOf('\n'));
   }
   else if (values[values.Length - 1].EndsWith("\n\r"))
   {
    values[values.Length - 1] = values[values.Length - 1].Substring(0, values[values.Length - 1].LastIndexOf("\n\r", StringComparison.Ordinal));
   }
   else if (values[values.Length - 1].EndsWith("\r"))
   {
    values[values.Length - 1] = values[values.Length - 1].Substring(0, values[values.Length - 1].LastIndexOf('\r'));
   }

   return values;
  }

  protected virtual void Dispose(bool cleanAll)
  {
   _iifSet?.Dispose();
  }

  public void Dispose()
  {
   Dispose(true);
   GC.SuppressFinalize(this);
  }

总结

好了,本文的内容到这就结束了,有关dataset的一些常用的操作,基本属性和方法在这里就不做介绍了。希望本文的内容对大家的学习或者工作能带来一定的帮助。

[!--infotagslink--]

相关文章

  • ASP.NET购物车实现过程详解

    这篇文章主要为大家详细介绍了ASP.NET购物车的实现过程,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-22
  • .NET Core下使用Kafka的方法步骤

    这篇文章主要介绍了.NET Core下使用Kafka的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-09-22
  • 在ASP.NET 2.0中操作数据之七十二:调试存储过程

    在开发过程中,使用Visual Studio的断点调试功能可以很方便帮我们调试发现程序存在的错误,同样Visual Studio也支持对SQL Server里面的存储过程进行调试,下面就让我们看看具体的调试方法。...2021-09-22
  • Win10 IIS 安装.net 4.5的方法

    这篇文章主要介绍了Win10 IIS 安装及.net 4.5及Win10安装IIS并配置ASP.NET 4.0的方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下...2021-09-22
  • 详解.NET Core 3.0 里新的JSON API

    这篇文章主要介绍了详解.NET Core 3.0 里新的JSON API,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-09-22
  • C#实现写入文本文件内容的方法

    这篇文章主要介绍了C#实现写入文本文件内容的方法,涉及C#针对文本文件的判断、创建及写入等相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • .net数据库操作框架SqlSugar的简单入门

    这篇文章主要介绍了.net数据库操作框架SqlSugar的简单入门,帮助大家更好的理解和学习使用.net技术,感兴趣的朋友可以了解下...2021-09-22
  • ASP.NET Core根据环境变量支持多个 appsettings.json配置文件

    这篇文章主要介绍了ASP.NET Core根据环境变量支持多个 appsettings.json配置文件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-09-22
  • 记一次EFCore类型转换错误及解决方案

    这篇文章主要介绍了记一次EFCore类型转换错误及解决方案,帮助大家更好的理解和学习使用asp.net core,感兴趣的朋友可以了解下...2021-09-22
  • C#从数据库读取数据到DataSet并保存到xml文件的方法

    这篇文章主要介绍了C#从数据库读取数据到DataSet并保存到xml文件的方法,涉及C#操作DataSet保存到XML文件的技巧,需要的朋友可以参考下...2020-06-25
  • C#实现向指定文本文件添加内容的方法

    这篇文章主要介绍了C#实现向指定文本文件添加内容的方法,涉及C#操作文本文件的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • .NET C#利用ZXing生成、识别二维码/条形码

    ZXing是一个开放源码的,用Java实现的多种格式的1D/2D条码图像处理库,它包含了联系到其他语言的端口。这篇文章主要给大家介绍了.NET C#利用ZXing生成、识别二维码/条形码的方法,文中给出了详细的示例代码,有需要的朋友们可以参考借鉴。...2020-06-25
  • 详解ASP.NET Core 中基于工厂的中间件激活的实现方法

    这篇文章主要介绍了ASP.NET Core 中基于工厂的中间件激活的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-09-22
  • C#使用Ado.Net更新和添加数据到Excel表格的方法

    这篇文章主要介绍了C#使用Ado.Net更新和添加数据到Excel表格的方法,较为详细的分析了OLEDB的原理与使用技巧,可实现较为方便的操作Excel数据,需要的朋友可以参考下...2020-06-25
  • asp.net通过消息队列处理高并发请求(以抢小米手机为例)

    这篇文章主要介绍了asp.net通过消息队列处理高并发请求(以抢小米手机为例),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-09-22
  • ASP.NET单选按钮控件RadioButton常用属性和方法介绍

    RadioButton又称单选按钮,其在工具箱中的图标为 ,单选按钮通常成组出现,用于提供两个或多个互斥选项,即在一组单选钮中只能选择一个...2021-09-22
  • ASP.NET 2.0中的数据操作:使用两个DropDownList过滤的主/从报表

    在前面的指南中我们研究了如何显示一个简单的主/从报表, 该报表使用DropDownList和GridView控件, DropDownList填充类别,GridView显示选定类别的产品. 这类报表用于显示具有...2016-05-19
  • C#实现读取DataSet数据并显示在ListView控件中的方法

    这篇文章主要介绍了C#实现读取DataSet数据并显示在ListView控件中的方法,涉及C#操作DataSet及ListView控件的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
  • 详解.NET Core 使用HttpClient SSL请求出错的解决办法

    这篇文章主要介绍了.NET Core 使用HttpClient SSL请求出错的解决办法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2021-09-22
  • Python调用.NET库的方法步骤

    这篇文章主要介绍了Python调用.NET库的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-05-09