unity中CSV文件一键转为json文件和CS代码文件

上个月基本啥都没干,基本都在折腾设计案和文件处理,咨询了一位大神,总算彻底梳理通了,今天把Editor模式下的转换模式补充了一下,算是CSV文件读取工作彻底完成。

读取json的【jsonReader】见上一篇日志:知乎专栏

这次把写的比较粗糙的生成json和CS文件的代码贴上来。【ExcelToJson.cs】

首先是命名空间,需要UnityEditor和SimpleJSON,因为是直接在工具的基础上改的,所以就没有改成LitJson,反正不是游戏代码,只是文件处理工具,多一个SimpleJSON文件也不会打包进去。

usingUnityEngine;usingSystem.Collections;usingUnityEditor;usingSystem.IO;usingSystem.Text;usingSimpleJSON;

接下来是2个导出文件的方法,本来只应用于json文件的导出。

在这个方法里面,MenuItem的作用是在Editor模式下在untiy中添加菜单选项ExcelToJson按钮,点击则使用此脚本。注意:使用MenuItem等添加editor菜单的方法一定要是static修饰的方法,否则没有按钮出现的。

这个方法的主要作用是调用outJsonContentToFile导出json文件,顺便设定下csv表格和json导出的路径。

[MenuItem("Tools/ExcelToJson")]staticvoidexcelToJson(){stringdataFolderPath=Application.dataPath+"/Document";stringoutJsonPath=Application.dataPath+"/Resources/Json";if(!Directory.Exists(dataFolderPath)){Debug.LogError("请建立"+dataFolderPath+" 文件夹,并且把csv文件放入此文件夹内");return;}string[]allCSVFiles=Directory.GetFiles(dataFolderPath,"*.csv");if(allCSVFiles==null||allCSVFiles.Length<=0){Debug.LogError(""+dataFolderPath+" 文件夹没有csv文件,请放入csv文件到此文件夹内");return;}if(!Directory.Exists(outJsonPath)){Directory.CreateDirectory(outJsonPath);}for(inti=0;i

然后就是接收json文本数据实现导出的方法,注意:需要添加UNITY_EDITOR的逻辑,目的是使用代码刷新unity的文件目录,不然你需要手动刷新,不刷新json文件是不会生成的

staticvoidoutJsonContentToFile(stringjsonData,stringjsonFilePath){stringdirectName=Path.GetDirectoryName(jsonFilePath);if(!Directory.Exists(directName)){Directory.CreateDirectory(directName);}File.WriteAllText(jsonFilePath,jsonData,Encoding.UTF8);Debug.Log("成功输出Json文件  :"+jsonFilePath);//在Editor模式下重新导入文件数据,刷新。#if UNITY_EDITORAssetDatabase.Refresh();#endif}

接下来就是处理csv数据和自动生成代码文件的主要逻辑了。详细讲解在下面进行——

staticstringreadExcelData(stringfileName){if(!File.Exists(fileName)){returnnull;}stringfileContent=File.ReadAllText(fileName,UnicodeEncoding.Default);string[]fileLineContent=fileContent.Split(newstring[]{"\r\n"},System.StringSplitOptions.None);stringclass_name=Path.GetFileNameWithoutExtension(fileName);if(fileLineContent!=null){//注释的名字string[]noteContents=fileLineContent[0].Split(newstring[]{","},System.StringSplitOptions.None);//变量的名字string[]VariableNameContents=fileLineContent[1].Split(newstring[]{","},System.StringSplitOptions.None);//变量类型的名字string[]TypeValue=fileLineContent[2].Split(newstring[]{","},System.StringSplitOptions.None);/*———————————生成CS的Class类脚本————————————*/StringBuildercode=newStringBuilder();//创建代码串//添加常见且必须的引用字符串code.Append("using UnityEngine; \n");code.Append("using System.Collections; \n");//产生类,所有可执行代码均在此类中运行code.Append("public class Class_"+class_name+" { \n\t");for(inti=0;i Class_Dic = JsonReader.ReadJson ("+docPath+");\n\t");code_Dic.Append("}\n");stringDicFilePath=Application.dataPath+"/Scripts/Script_Doc_SD";stringDicName=Path.GetDirectoryName(DicFilePath);if(!Directory.Exists(DicName)){Directory.CreateDirectory(DicName);}if(!Directory.Exists(DicFilePath)){Directory.CreateDirectory(DicFilePath);}FileStreamfs2=newFileStream(DicFilePath+"/"+"/SD_"+class_name+".cs",FileMode.OpenOrCreate,FileAccess.Write);StreamWritersw2=newStreamWriter(fs2,Encoding.UTF8);sw2.Write(code_Dic.ToString());sw2.Close();fs2.Close();//File.WriteAllText(DicFilePath + "/" + DDicdictName + "/SD_" + DDicfileName + ".cs", code_Dic.ToString(), Encoding.UTF8);Debug.Log("成功生成c#的Dic文件"+class_name+".cs"+"在目录:"+DicFilePath+" 中");/*————————解析表格字符串————————————*/JSONClassjsonData=newJSONClass();for(inti=3;i

这一段代码比较复杂,中间使用了3条分割线用于说明代码块的区域。

第一段是使用File.ReadAllText读取csv里面的数据保存为string类型的数组,然后处理文件名的路径,得到纯粹的文件名,再得到注释的名字数组、变量的名字数组、变量类型的数组。

在这里的代码逻辑中,约定csv表格内容的填写方式如下:

1.第一行为注释(中文)行,不作处理。

2.第二行为字段名行,非数据。

3.第三行填写字段的类型,用于生成cs文件。

4.第一列为每一行的唯一索引id,用于找到每一行使用。

如果不按照上述填法就会发生报错或者取不到数值的情况。

第二段为生成cs的Class类的脚本。使用StringBuilder和code.Append()存储我们写入的每一行的代码的文本,使用\n换行,使用\t缩进。Class类的数据我们通过上面的取值可以得到。

注意:在这里只进行了int、float和string的方法封装,如需其他数据类型自行添加,同时请务必保证csv填写不会出现无法转换的字符。

第三段为生成cs的字典的类的脚本,用于存放静态的字典数据,通过jsonReader得到每个表格中的所有数据存储到字典中,再赋给每个类对象中的每个字段数据。由于是静态存储的字典,所以修改数据时需要在相关代码中再进行创建字典存储修改后的数据。

注意:我在这里使用了StreamWriter而非file.writeAllText是因为后者会发生没有权限写入数据的情况(很诡异,因为在第一个方法里面用了writeAllText却没有问题)。

第四段为解析表格字符串的代码,逻辑也很简单,通过存储每一行的数据按照json的格式返回总的字符串,然后通过前两个方法写入json文件。

生成后的代码文件如下:

取值的方式在jsonReader的逻辑里面说过了就不再赘述。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,319评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,801评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,567评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,156评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,019评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,090评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,500评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,192评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,474评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,566评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,338评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,212评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,572评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,890评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,169评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,478评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,661评论 2 335

推荐阅读更多精彩内容