前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >unity3d:csv读取数据,兼容单元格中包含逗号

unity3d:csv读取数据,兼容单元格中包含逗号

作者头像
立羽
发布2023-08-24 14:19:19
发布2023-08-24 14:19:19
23900
代码可运行
举报
文章被收录于专栏:Unity3d程序开发Unity3d程序开发
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
复制
using UnityEngine;
using System.Linq;
using System;
using System.Text;
using System.Collections;
using System.Collections.Generic;

public class CSV
{
	public string[] header;
	public List<string> lines;
}

public static class CSVReader {
	private static readonly string splitter = "[liyu]";
	private static readonly string[] splitters = new string[]{splitter};
	public static CSV Read(string text)
	{
		CSV csv = new CSV();
		text = text.Trim().Replace("\r", "") + "\n";

		// read cells
		csv.lines = new List<string>();
		bool startCell = false;
		StringBuilder line = new StringBuilder();
		for(int i=0; i<text.Length; ++i)
		{
			char c = text[i];
			if(c == '"')
			{
				if(text[i+1] == '"') i++;
				else
				{
					startCell = !startCell;
					continue;
				}
			}
			else if(!startCell && c == ',')
			{
				line.Append(splitter);
				continue;
			}
			else if(!startCell && c == '\n')
			{
				csv.lines.Add(line.ToString());
				line.Length = 0;
				continue;
			}
			line.Append(c);
		}
		string lastLine = line.ToString().Trim();
		if(!string.IsNullOrEmpty(lastLine)) csv.lines.Add(lastLine);

		// add line number
		//csv.lines = csv.lines.Select((t, index) => string.Format("{0}{2}{1}", (index > 0 ? (index+1).ToString() : "line"), t, splitter)).ToList();

		// get header
		csv.header = ParseLine(csv.lines[0]);
		csv.lines.RemoveAt(0);

		return csv;
	}

	public static string[] ParseLine(string line)
	{
		return line.Split(splitters, StringSplitOptions.None);
	}

}

public class CSVMgr
{
    public static List<string[]> GetData(string path)
    {
        string tipString = JsonMgr.GetJsonString(Application.streamingAssetsPath + "/" + path);

        List<string[]> rows = new List<string[]>();
        CSV csv = CSVReader.Read(tipString);
        csv.lines.ForEach(line => rows.Add(CSVReader.ParseLine(line)));
        return rows;
    }
        public static List<string[]> GetDataFromRes(string path)
    {
        TextAsset ta = Resources.Load<TextAsset>(path);
        string tipString = ta.text;

        List<string[]> rows = new List<string[]>();
        CSV csv = CSVReader.Read(tipString);
        csv.lines.ForEach(line => rows.Add(CSVReader.ParseLine(line)));
        return rows;
    }
}

读取时把csv文件转化为List<string[]>,再用for循环进行解析

代码语言:javascript
代码运行次数:0
复制
        List<string[]> rows = new List<string[]>();
        rows = CSVMgr.GetDataOri("CsvTest.csv");
        for (int i = 0; i < rows.Count; i++)
        {
            m_dic[rows[i][0].ToString()] = rows[i][1].ToString();
        }

由于excel导出csv不好转utf8,并且不能打开时跑程序,所以推荐个编辑器Ron‘s Editor csv编辑器https://www.ronsplace.eu/Products/RonsEditor/Download

编辑器中

用txt打开

说明: 1.如果单元格中包换了英文逗号,txt中会自动加上""包住整个单元格 2.如果单元格中包含了英文双引号,txt中会自动再加上一层双引号

所以,在程序读取时 1.先重新组装每一行,碰到单个字符为",判断后一个有无引号,有即是单元格中包含字符",无即是单元格中包含字符,

代码语言:javascript
代码运行次数:0
复制
for (int i = 0; i < text.Length; ++i)
        {
            char c = text[i];
            if (c == '"')
            {
                if (text[i + 1] == '"') i++;
                else
                {
                    startCell = !startCell;
                    continue;
                }
            }
            else if (!startCell && c == ',')
            {
                line.Append(splitter);
                continue;
            }
            else if (!startCell && c == '\n')
            {
                csv.lines.Add(line.ToString());
                line.Length = 0;
                continue;
            }
            line.Append(c);
        }

2.判断到字符,作用是分隔符,用个字符串替"[liyu]"换它,解析时用这个特定字符Split切割,这样兼容单元格中包含逗号

代码语言:javascript
代码运行次数:0
复制
line.Split(splitters, StringSplitOptions.None);
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-05-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档