在游戏开发过程中,经常要用到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. 用sticky.js实现头部导航栏固定

    在页面中,如果页面长度过大,滑动页面时,头部导航栏则会跟着划走. 我的头部导航栏代码为: <div class="headbar"> <center class= ...

  2. Linux常见命令之权限管理命令

    chmod命令 chmod命令用来变更文件或目录的权限.在UNIX系统家族里,文件或目录权限的控制分别以读取.写入.执行3种一般权限来区分,另有3种特殊权限可供运用.用户可以使用chmod指令去变更文 ...

  3. Web前端——Html常用标签及属性

    html 常用的标题等标签就不记录了,只记录一下比较少见的标签以及属性 表格 table td 单元格 tr 表的行 th 表头 td或th可以下面的两个属性达到跨行或跨列 表格跨行 rowspan ...

  4. Koa 中间件的执行

    Node.js 中请求的处理 讨论 Koa 中间件前,先看原生 Node.js 中是如何创建 server 和处理请求的. node_server.js const http = require(&q ...

  5. 学习Python前言

    先介绍下自己: 我是小芒果,在一家互联网公司上班 目前担任的是测试工程师职 自工作开始至今,已经3年之载 一路过来倒也轻松 期间学过几次python没一次能坚持下来 随着行业的饱和 测试技术的要求 以 ...

  6. .NET MVC5简介(一)

    就像是.NET Framework WebApi与.NET Core WebApi一样,.NET Framework MVC与.NET Core MVC的区别,也是框架的之间的区别.本系列先首先从.N ...

  7. xamarin Android 监听音量键(上)

    public override bool OnKeyDown([GeneratedEnum]Android.Views.Keycode keyCode, KeyEvent e) { switch (k ...

  8. SourceInsight教程

    概述: Source Insight是一个面向项目开发的程序编辑器和代码浏览器,它拥有内置的对C/C++, C#和Java等程序的分析.Source Insight能分析你的源代码并在你工作的同时动态 ...

  9. gitlab设置项目组成员权限

    你敢相信这是个码农? setting菜单的“Members”功能页: 该页面展示了当前Project的成员列表,以及每个成员对应的权限角色,Owner/Master/Developer 注意到该页面顶 ...

  10. window下操作jenkins查看页面的几种方式

    原文:https://blog.csdn.net/kennin19840715/article/details/78782505 前几天通过jenkins本机执行selenium cases, 发现浏 ...