在游戏开发过程中,经常要用到Excel编辑各类数据,如果可以直接用Excel支持的文件格式来读取数据,修改将非常便捷。

Excel支持导出CSV类型的文件,这类文件不仅可以用Excel直接打开修改,即便用记事本打开也非常容易阅读,解析起来也很简单。

下面给出CSV文件的解析类:

 using UnityEngine;
using System.IO;
using System.Text; public class CSV { static CSV csv;
public static CSV GetIns()
{
if (csv == null)
csv = new CSV();
return csv;
} //利用二维数组存储对应行和列中的字符串
public string[][] m_ArrayData; public void LoadFile(string path,string fileName)
{
//读取新文件前保证之前的数据为空
m_ArrayData = new string[][];
string fillPath = path + "/" + fileName; //解析每一行的数据
string[] lineArray;
try
{
//注意编码方式,这里用的是Windows系统自定义的编码方式Encoding.Default,其实也就是GB2312(简体中文),编码不对应的话解析出来很可能是乱码
lineArray = File.ReadAllLines(fillPath, Encoding.Default);
Debug.Log("file finded!");
}
catch
{
Debug.Log("file do not find!");
return;
} m_ArrayData = new string[lineArray.Length][];
for (int i = ; i < lineArray.Length; i++)
{
//CSV格式的文件采用英文逗号作为分隔符
m_ArrayData[i] = lineArray[i].Split(',');
}
} //外部调用的取值接口,需要先LoadFile()后才能返回正确的数据
public string GetVaule(int row,int col)
{
return m_ArrayData[row][col];
}

2019.09.18日更新:

1.上面的代码在Windows平台下运行是没问题的,后来发现在安卓端就会出现乱码问题;查阅资料后发现移动端一般不支持Window平台默认的GB2312(简体中文)编码方式。

解决办法就是将文本修改为utf-8的编码,统一采用utf-8来解析文本,无论在Window还是移动端,utf-8都是支持的。

文本的修改方式是直接用记事本打开csv文件,选择另存为,在编码那一栏修改为带BOM的UTF-8,注意一定要带BOM,不然Excel没办法正确读取,保存类型为所有文件:

然后将上面代码的解析方式也改为utf-8即可:

lineArray = File.ReadAllLines(fillPath, Encoding.GetEncoding("utf-8"));

2.在安卓端直接用File类读取配置文件是有问题的,因为即使把CSV文件放到StreamingAssets中也是没办法直接读到的,必须要用Unity提供的WWW类(或者新版的UnityWebRequest)流式读取才行。

好在Application.persistentDataPath的地址无论在哪个平台上都能够得到正确的地址,而且在移动端是可读可写的,这一点非常重要。因此,可以采取这样的操作:

先用WWW类(或者新版的UnityWebRequest)将StreamingAssets文件夹下的CSV文件读取出来,然后再重新写到Application.persistentDataPath中去,之后就可以轻松用File类在Application.persistentDataPath地址下去读取CSV了。

这样的话也不用再考虑平台的差异性了:

     IEnumerator LoadCSV(string fileName,UnityAction CompleteAction)
{
string sPath = Application.streamingAssetsPath + "/" + fileName;
Debug.Log("sPath:" + sPath);
WWW www = new WWW(sPath);
while (!www.isDone)
{
yield return null;
}
Debug.Log("content2:" + www.text);
File.WriteAllText(Application.persistentDataPath + "/" + fileName, www.text, Encoding.GetEncoding("utf-8"));
CSV.GetIns().LoadFile(Application.persistentDataPath, fileName);
CompleteAction();
}

Unity C# CSV文件解析与加载(已更新移动端处理方式)的更多相关文章

  1. 基于FBX SDK的FBX模型解析与加载 -(一)

    http://blog.csdn.net/bugrunner/article/details/7210511 1. 简介 FBX是Autodesk的一个用于跨平台的免费三维数据交换的格式(最早不是由A ...

  2. Unity开发实战探讨-资源的加载释放最佳策略简要心得

    Unity开发实战探讨-资源的加载释放最佳策略简要心得 看过我另外一篇关于Unity资源释放随笔<Unity开发实战探讨-资源的加载释放最佳策略>如果觉得略微复杂,那么下面是一些比较简要的 ...

  3. Mybatis源码解析(二) —— 加载 Configuration

    Mybatis源码解析(二) -- 加载 Configuration    正如上文所看到的 Configuration 对象保存了所有Mybatis的配置信息,也就是说mybatis-config. ...

  4. vue第七单元(vue的单文件组件形式-单文件组件的加载原理-vue-cli构建的开发环境以及生命周期)

    第七单元(vue的单文件组件形式-单文件组件的加载原理-vue-cli构建的开发环境以及生命周期) #课程目标 掌握安装 vue-cli 命令行工具的方法,掌握使用命令行在本地搭建开发环境,使用命令行 ...

  5. 如何使用 require.js ,实现js文件的异步加载,避免网页失去响应,管理模块之间的依赖性,便于代码的编写和维护。

    一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载.下面的网页代 ...

  6. profile文件的错误加载与基本命令间的映射

    一.绪论 [因为这篇心得是原创的,所以如果有哪处总结或者意见不足的地方,欢迎各位大神的批评和意见,共同学习,谢谢了!] 早些时候,需要在centos6.4系统中配置单机版和集群版单节点的hadoop ...

  7. 本地修改配置hosts文件解决Github加载慢问题

    本地修改配置hosts文件解决Github加载慢问题 手动方式 hosts 文件在每个系统的位置不一,详情如下: Windows 系统:C:\Windows\System32\drivers\etc\ ...

  8. iOS --- UIWebView的加载本地数据的三种方式

    UIWebView是IOS内置的浏览器,可以浏览网页,打开文档  html/htm  pdf   docx  txt等格式的文件.  safari浏览器就是通过UIWebView做的. 服务器将MIM ...

  9. Jquery 在页面加载后执行的几种方式

    1.$(function(){  $("#a").click(function(){  //adding your code here  }); }); 2.$(document) ...

随机推荐

  1. dotnetcore实现Aop

    dotnetcore实现Aop Aop大家都不陌生,然而今天给大家不将讲官方的filter,今天给大家分享一个轻量级的Aop解决方案(AspectCore) 什么是AspectCore AspectC ...

  2. 13-scrapy中selenium的应用

    一. 引入 在通过scrapy框架进行某些网站数据爬取的时候,往往会碰到页面动态数据加载的情况发生,如果直接使用scrapy对其url发请求,是绝对获取不到那部分动态加载出来的数据值.但是通过观察我们 ...

  3. pytest框架之mark标签

    对测试用例打标签,在运行测试用例的时候,可根据标签名来过滤要运行的用例. 一.注册标签名 1.创建pytest.ini文件,在文件中按如下方式添加标签名: [pytest] markers = smo ...

  4. Ansible之roles角色

    一.roles简介 ansible自1.2版本引入的新特性,用于层次性.结构化地组织playbook.roles能够根据层次型结构自动装载变量文件.tasks以及handlers等.要使用roles只 ...

  5. 鸟哥的Linux私房菜笔记第五章,文件权限与目录配置(二)

    Linux目录配置的依据--FHS 因为利用Linux来开发产品的公司太多,例如,CentOS.Ubuntu.ReHat...,导致了配置文件存放的目录没有统一的标准.后来就有了FHS(Filesys ...

  6. Newtonsoft.Json 指定某个属性使用特定的时间格式

    Newtonsoft.Json 指定某个属性使用特定的时间格式 Intro Newtonsoft.Json 是 .NET 下最受欢迎 JSON 操作库,原为 JSON.Net 后改名为 Newtons ...

  7. Redis系列---安装redis单机版02

    本章将带领大家一步一步安装Redis单机版(Redis从3.0版本后就开始支持集群了,集群将会后边章节带领大家操作) 准备环境: Centos 6.X redis3.+版本(自行下载,redis 的版 ...

  8. ls用法

    常用 ll -h  大小直接显示K,M,G 语 法:ls [-1aAbBcCdDfFgGhHiklLmnNopqQrRsStuUvxX][-I <范本样式>][-T <跳格字数> ...

  9. 自学_CSS<二>

    CSS CSS(层叠样式表)是用来美化页面用的,可以对页面元素进行更精细的设置,样式主要描述元素的字体颜色.背景颜色.边框等. CSS主要有元素内联.页面嵌入和外部引用三种使用方式.CSS是描述元素的 ...

  10. centos 配置sentry+钉钉+邮件通知

    1.sentry官方推荐docker方式安装.使用docker-compose,最好是centos7 2.卸载旧版本 yum remove docker docker-common docker-se ...