加载读取CSV,txt逗号分格值文件

2024-04-23 00:38
文章标签 加载 读取 csv txt 逗号 分格

本文主要是介绍加载读取CSV,txt逗号分格值文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

游戏开发中,经常会使用到很多配置文件。适当的利用配置文件,可以有效实现程序设计的灵活性,避免对程序功能的不断修改,降低程序开发人员与策划人员之间的沟通成本,提高效率。

比如以下情景

一个玩家,初始hp200,初始mp200,攻击10

我们可以采用两种方案来完成,

左边 右边
组件里直接写代码
Player.HP=200;
Player.MP=200;
Player.Aggress=10;
ID,MP , HP , Aggress
1 ,200 , 200,10
组件里写代码
Player.HP = GetConfigValue(1,“HP”);
Player.MP=GetConfigValue(1,“MP”);
Player.Aggress=GetConfigValue(1,“Aggress”);

当策划(万恶的策划,本篇的主要反面人物)说哎呀,不行,玩家的初始HP要改成500。

从我们的出发点来衡量:

左边,灾难,玩家要再经历一次下载安装客户端的煎熬。

右边,只要让PlayerConfig更新到客户端,这就可以在玩家重启客户端的时候完成。

左边,不符合资源更新的精神。

右边,符合。

在这里我们写一个读取配置文件的工具类
using UnityEngine;
using System.Collections.Generic;public class ExcelData
{/// <summary>/// 读取加载TXT配置文件/// </summary>/// <param name="cfgName">配置表名称</param>/// <param name="DicContent"></param>public static void LoadExcelFormCSV(string cfgName, out Dictionary<string, Dictionary<string, string>> DicContent){//创建一个TextAsset,通过Resources.Load来加载配置表TextAsset tw = Resources.Load("Cfg/" + cfgName) as TextAsset;//存放数据表里面的所有内容string strLine = tw.text;//创建一个字典,用于存放数据表的内容(从配置表第四行读取)//<字段名,字段值(string数组)>Dictionary<string, string[]> content = new Dictionary<string, string[]>();//开始解析字符串ExplainString(strLine, content, out DicContent);}/// <summary>/// 解析字符串/// </summary>/// <param name="strLine">配置文件字符串</param>/// <param name="content">数据表内容</param>/// <param name="DicContent"></param>public static void ExplainString(string strLine, Dictionary<string, string[]> content, out Dictionary<string, Dictionary<string, string>> DicContent){//创建一个字典,用于存放默认值的//<字段名,默认值>Dictionary<string, string> initNum = new Dictionary<string, string>();//通过换行符来切割配置表里面的内容,使之成为一行一行的数据string[] lineArray = strLine.Split(new char[] { '\n' });//获取行数int rows = lineArray.Length - 1;//最后一行包含换行符,行数需要因此减去1//获取列数int Columns = lineArray[0].Split(new char[] { ',' }).Length;//定义一个数组用于存放字段名string[] ColumnName = new string[Columns];for (int i = 0; i < rows; i++){//每一行数据都根据逗号进行分割,得到一个数组string[] Array = lineArray[i].Split(new char[] { ',' });for (int j = 0; j < Columns; j++){//获取Array的列的值string nvalue = Array[j].Trim();//第一行字段名if (i == 0){//存储字段名ColumnName[j] = nvalue;//实例化字典,长度为rows - 3,因为是从第四行读取content[ColumnName[j]] = new string[rows - 3];}//if (i == 1)//此时是读到配置表的第二行(字段的注释),不做处理,配置表所填的值,类型都为string//{                  //}else if (i == 2)//第三行默认值{//存储对应字段的默认值//<字段名,默认值>initNum[ColumnName[j]] = nvalue;}else if (i >= 3)//第三行开始是实际数据,存储实际数据{//<字段名,字段值(string数组)>content[ColumnName[j]][i - 3] = nvalue;if (nvalue == "")//如果读到的值为空字符,则给予默认值(默认值就是配置表第三行所填的值){content[ColumnName[j]][i - 3] = initNum[ColumnName[j]];//<字段名,字段值(string数组)>}}}}//开始解析ExplainDictionary(content, out DicContent);}/// <summary>/// 解析字典中的数据/// </summary>/// <param name="content"></param>/// <param name="DicContent"></param>public static void ExplainDictionary(Dictionary<string, string[]> content, out Dictionary<string, Dictionary<string, string>> DicContent){//实例化字典//<字段名><<ID><字段值>>DicContent = new Dictionary<string, Dictionary<string, string>>();//获取字典中所有的键(字段名)Dictionary<string, string[]>.KeyCollection Allkeys = content.Keys;//遍历所有的字段名foreach (string key in Allkeys){//实例化一个hasData的字典//<ID,字段值>Dictionary<string, string> hasData = new Dictionary<string, string>();//获取当前遍历到的key(字段名)所对应的字段值,存到数组里面string[] Data = content[key];//循环这个数组for (int i = 0; i < Data.Length; i++){//<ID><字段值>hasData[content["ID"][i]] = Data[i];}//最后给DicContent这个字典赋值DicContent[key] = hasData;//<字段名><<ID><字段值>>}}}

注释写的非常清楚就再一一解释了,在使用的时候我们需要调用ExcelData.LoadExcelFormCSV("TextCfg",out m_DicLanguageText) 传入我们需要加载的配置文件,第二个参数传入我们的字典 Dictionary<string, Dictionary<string, string>> m_DiclText;

需要注意这里我们的配置文件是存放在Resources/Cfg目录下的

这里写出一个配置文件的例子:

ID,ChineseText,EnglishText
//流水id,//中文,//英文
-1,-1,-1
1,关卡,Level
2,背包,Packsack


当我们需要获取配置表中数据时只需要通过获取字典的键值对方法就可以寄读取了

   /// <summary>/// 读取数据的方法/// </summary>/// <param name="keyWord">字段名</param>/// <param name="id">物品ID</param>/// <returns></returns>public string ReadData(string keyWord,int id, Dictionary<string, Dictionary<string, string>> theDic){return theDic[keyWord][id.ToString()];}

获取配置表中的数据量:

    /// <summary>/// 获得配置表的数据量/// </summary>/// <param name="theDic">配置表</param>/// <returns></returns>public int GetInforCount(Dictionary<string, Dictionary<string, string>> theDic){int count = 0;foreach (KeyValuePair<string,Dictionary<string,string>> item in theDic){count = item.Value.Count;break;}return count;}




这篇关于加载读取CSV,txt逗号分格值文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/927318

相关文章

Python如何将大TXT文件分割成4KB小文件

《Python如何将大TXT文件分割成4KB小文件》处理大文本文件是程序员经常遇到的挑战,特别是当我们需要把一个几百MB甚至几个GB的TXT文件分割成小块时,下面我们来聊聊如何用Python自动完成这... 目录为什么需要分割TXT文件基础版:按行分割进阶版:精确控制文件大小完美解决方案:支持UTF-8编码

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

SpringBoot项目启动报错"找不到或无法加载主类"的解决方法

《SpringBoot项目启动报错找不到或无法加载主类的解决方法》在使用IntelliJIDEA开发基于SpringBoot框架的Java程序时,可能会出现找不到或无法加载主类com.example.... 目录一、问题描述二、排查过程三、解决方案一、问题描述在使用 IntelliJ IDEA 开发基于

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码

利用Python实现添加或读取Excel公式

《利用Python实现添加或读取Excel公式》Excel公式是数据处理的核心工具,从简单的加减运算到复杂的逻辑判断,掌握基础语法是高效工作的起点,下面我们就来看看如何使用Python进行Excel公... 目录python Excel 库安装Python 在 Excel 中添加公式/函数Python 读取

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin

C# winform操作CSV格式文件

《C#winform操作CSV格式文件》这篇文章主要为大家详细介绍了C#在winform中的表格操作CSV格式文件的相关实例,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录实例一实例效果实现代码效果展示实例二实例效果完整代码实例一实例效果当在winform界面中点击读取按钮时 将csv中