RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1237362
Accepted
Андрей Котов
Андрей Котов
Asked:2022-01-29 16:37:33 +0000 UTC2022-01-29 16:37:33 +0000 UTC 2022-01-29 16:37:33 +0000 UTC

在分隔符 C# 处拆分字符串

  • 772

我有一个包含 2 列数字的 csv 文件

3,"5,19615242270663"
"4,5",8
6,"11,1803398874989"

如何从此列表中获取二维数字数组?

c#
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. VladD
    2022-01-29T17:36:44Z2022-01-29T17:36:44Z

    如果你需要实现这个进行学习或培训:我不会给出现成的代码以便你自己学习,我只会给出提示。

    看,你需要写一个真正的解析器。您可以在引号中使用逗号,因此“天真”地解析string.Split将不起作用。做这个。

    一次扫描一个字符的字符串。获取一个标志,指示您当前是否在引号内。

    如果在引号之外遇到逗号,则上一个条目已结束。如果在这种模式下遇到换行符(CR + LF),那么 CSV 行就结束了。如果在录制开始时遇到引号,请切换到“引用”模式。不在条目开头的引号是格式违规。

    如果您在引号内看到逗号,这不是条目的结尾,请继续扫描。如果遇到引号,请退出引号模式,除非下一个字符是引号。(如果下一个字符是引号,那么这两个引号一起在条目值中形成一个引号。)如果遇到换行符,它不会结束该行,而是包含在条目中。退出报价模式后,必须有记录的结尾,即逗号,或者CR + LF,或者文本的结尾,否则CSV无效。

    获得所有条目后,确保每一行包含相同数量的条目(这也可以在解析文本时完成)。第一行可以包含(或不包含)列名,所有后续行都包含值。

    现在您可以尝试将所有记录转换为double使用double.TryParse.

    如果有的话,这里是一个带有格式描述的 RFC:https ://www.rfc-editor.org/rfc/rfc4180 。


    如果这不是一项教育任务,那么请使用普通的 CSV 解析器,不要制造自行车。

    • 7
  2. Best Answer
    aepot
    2022-01-29T18:50:05Z2022-01-29T18:50:05Z

    您需要的“天真”实现,能够从问题中消化您的示例,可能看起来像这样。

    static void Main(string[] args)
    {
        string text = @"3,""5,19615242270663""
    ""4,5"",8
    6,""11,1803398874989""
    ";
        try
        {
            double[,] numbers = CsvToDoubleArray(text);
            for (int i = 0; i < numbers.GetLength(0); i++)
                Console.WriteLine(string.Join(" ", Enumerable.Range(0, numbers.GetLength(1)).Select(j => numbers[i, j])));
        }
        catch (Exception ex)
        {
            Console.WriteLine(ex.Message);
        }
    
    }
    
    static double[,] CsvToDoubleArray(string text)
    {
        string[] lines = text.Split(Environment.NewLine, StringSplitOptions.RemoveEmptyEntries);
        double[,] result = null;
        for (int i = 0; i < lines.Length; i++)
        {
            string line = lines[i];
            List<string> tokens = new List<string>();
            StringBuilder token = new StringBuilder();
            bool mode = false;
            for (int j = 0; j < line.Length; j++)
            {
                switch (line[j])
                {
                    case '\\':
                        j++;
                        if (j < line.Length)
                            token.Append(line[j]);
                        break;
                    case '"':
                        mode = !mode;
                        break;
                    case ',':
                        if (mode)
                            token.Append(line[j]);
                        else
                        {
                            tokens.Add(token.ToString());
                            token.Clear();
                        }
                        break;
                    default:
                        token.Append(line[j]);
                        break;
                }
            }
            tokens.Add(token.ToString());
            if (result == null)
                result = new double[lines.Length, tokens.Count];
            for (int j = 0; j < result.GetLength(1); j++)
            {
                result[i, j] = double.Parse(tokens[j]);
            }
        }
        return result;
    }
    

    此代码可能需要在不同方向上进行大量工作,从处理 CSV 中的不同错误到支持不同的分隔符,以及@VladD 的相邻答案中提到的其他要点。这个例子的重点是它适用于您提供的数据。我不知道它将如何与其他数据一起使用。

    控制台输出

    3 5,19615242270663
    4,5 8
    6 11,1803398874989
    
    • 3

相关问题

  • 使用嵌套类导出 xml 文件

  • 分层数据模板 [WPF]

  • 如何在 WPF 中为 ListView 手动创建列?

  • 在 2D 空间中,Collider 2D 挂在玩家身上,它对敌人的重量相同,我需要它这样当它们碰撞时,它们不会飞向不同的方向。统一

  • 如何在 c# 中使用 python 神经网络来创建语音合成?

  • 如何知道类中的方法是否属于接口?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5