博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LitJson(读Exce文件写入到json文件):
阅读量:4673 次
发布时间:2019-06-09

本文共 1945 字,大约阅读时间需要 6 分钟。

读Exce文件写入到json文件汇总:

//命名空间

using System.Collections;

using System.Collections.Generic;

using System.IO;

using UnityEngine;

using  UnityEditor;

using  Excel;

using  LitJson;

using  OfficeOpenXml;

public class ExcelData     //定义ExcelData类

{

    //定义表格的内容变量名称

    public string UserName;

    public string UserPwd;

}

//定义unity中窗口类

public class XiaoLang : EditorWindow

{

    public XiaoLang()

 

    {

        //设置窗口的名字

        this.titleContent = new GUIContent("测试窗口");

    }

    //扩展编译器

    [MenuItem("MyTools/windows")]

    static void MyWindows()

    {

        //固定套路格式

        GetWindow(typeof(XiaoLang));

    }

    void OnGUI()

    {

         //定义窗口点击

        if (GUILayout.Button("读取Excel至json文件", GUILayout.Width(200)))

        {

                 //点击调用的方法

            WriteExcelDataToJson();

        }

    }

    //WriteExcelDataToJson方法

    private void WriteExcelDataToJson()

    {

         //定义excel、Json文件路径

        string excelPath = Application.streamingAssetsPath + "/userInfo.xlsx";

        string JsonPath = Application.streamingAssetsPath + "/userInfo.json";

         //定义数据存储的List

        List<ExcelData> data = new List<ExcelData>();

         //固定读写格式

        ReadExcelData(data,excelPath);

        WriteDataToJson(data, JsonPath);

        AssetDatabase.Refresh();

    }

    //ReadExcelData方法、参数List、参数路径

    private void ReadExcelData(List<ExcelData> data, string excelPath)

    {

         //定义读取信息

        FileInfo info = new FileInfo(excelPath);

        if (info.Exists == false)

        {

            Debug.Log("Excel文件不存在.");

            return;

        }

        //固定读取数据流

        FileStream stream = new FileStream(excelPath,FileMode.Open,FileAccess.Read);

        IExcelDataReader reader = ExcelReaderFactory.CreateOpenXmlReader(stream);

         //读取文件首行

        reader.Read();

         //读取文件首行

        while (reader.Read())

        {

             //读取文件格式并添加到List中

            ExcelData exceldata = new ExcelData();

            exceldata.UserName = reader.GetString(0);

            exceldata.UserPwd = reader.GetString(1);

            data.Add(exceldata);

        }

    }

    //WriteDataToJson方法、参数List、参数路径

    private void WriteDataToJson(List<ExcelData> data, string jsonPath)

    {

         //固定写Json文件格式

        string jsonData = JsonMapper.ToJson(data);

        File.WriteAllText(jsonPath,jsonData);

    }

}

注:代码使用LitJson插件完成、其方法基于LitJson代码、用于Excel文件与Json文件之间的转换、原理雷同

转载于:https://www.cnblogs.com/XiaoLang0/p/9565680.html

你可能感兴趣的文章
mysql 无法链接, 输入密码失败
查看>>
java中enum类型的使用
查看>>
枚举类型转换成字符串
查看>>
(剑指Offer)面试题46:求1+2+3+....+n
查看>>
连续子数组的最大和(基于动态规划)
查看>>
Word Search
查看>>
三:背包DP
查看>>
Nikto学习点
查看>>
OSi七成模型 tcp/ip网络模型
查看>>
初学python之路-day15
查看>>
Linux内核分析——进程的描述和进程的创建
查看>>
【C++自我精讲】基础系列三 重载
查看>>
企业级docker私有仓库的配置与使用
查看>>
ireport5.6+jasperreport6.3开发(四)--以javabean为基准的报表开发(ireport)
查看>>
Spring面试底层原理的那些问题,你是不是真的懂Spring?
查看>>
Java知识导航总图
查看>>
关于Ajax的实现
查看>>
$cast
查看>>
js 把字符串格式化成时间
查看>>
关于老师
查看>>