csv 文件中,如果值中有分隔符,分隔符需要转义,否则会被解析掉.比如:你好\,世界,你是谁?,张三.你好,世界 需要作为一个整体解析.写了一个小方法,记录一下.
public static List<String> parseCSV(String s, char seprator) { char[] cs = s.toCharArray(); List<String> list = new ArrayList<String>(); StringBuilder sb = new StringBuilder(); int pi = -1; for(int i = 0; i < cs.length; i++) { char c = cs[i]; if (c == '\\') { sb.append(c); pi = i; continue; } if (c != seprator) { sb.append(c); continue; } if (pi + 1 == i) { // 是转义符 sb.deleteCharAt(sb.length() - 1); sb.append(c); pi = -1; } else { // 是分隔符 list.add(sb.toString()); sb.delete(0, sb.length()); } } list.add(sb.toString()); return list; }
string.split(",")是正则分割,并且不能检索"\".上面的方法是字符检索,经过测试,上面的方法比split要快一些 (3-4倍).
int i = 0; long start = System.currentTimeMillis(); do { parseCSV(content, ','); } while (i++ < 10000); long end = System.currentTimeMillis(); System.out.println("" + (end - start)); long start2 = System.currentTimeMillis(); i = 0; do { content.split(","); } while (i++ < 10000); long end2 = System.currentTimeMillis(); System.out.println("" + (end2 - start2));
另外一个小工具方法,http query string 解析:
public static Map<String, String> parseQueryString(String queryString) { Map<String, String> result = new HashMap<String, String>(); String[] eles = queryString.split(",|&"); for (String ele : eles) { String[] kv = ele.split(":|=", 2); result.put(kv[0], kv[1]); } return result; }
相关推荐
在这个场景下,"flex CSV解析"指的是使用Flex来读取和处理CSV文件中的数据。 CSV文件的结构非常简单,每一行代表一个记录,每个字段由逗号分隔。解析CSV文件的关键在于正确识别字段边界和转义规则。在Flex中,可以...
使用c++开发的csv文件解析类。 namespace cpp { namespace str { /** 高性能的 csv 解析 */ class csv_parser { public: typedef std::pair, size_t > string_t; typedef std::vector<string_t > fields_t; ...
OpenCSV是一个强大的CSV解析器,它为Java开发者提供了方便的方式来读写CSV文件。 OpenCSV的核心功能包括: 1. **读取CSV文件**:OpenCSV提供了一个`CSVReader`类,它能够逐行读取CSV文件并将其转换为Java对象。你...
本项目提供了一个简单的C++ CSV解析程序,能够处理以逗号、分号或制表符作为分隔符的CSV文件,这为不熟悉复杂库的开发者提供了一个快速入门的解决方案。 程序主要由三个文件组成: 1. `csv_parser.cpp`:这是实现...
Qt没有内置的CSV解析器,但可以通过标准的文本流(QTextStream)或自定义实现来处理。在描述中提到的"CSVparser类"可能是项目中自定义的一个类,用于读取和解析CSV文件。通常,这个类会逐行读取文件,然后根据逗号...
`neat-csv` 就是一个专门为 Node.js 设计的快速、简洁的 CSV 解析器库。 `neat-csv` 库由 Sindre Sorhus 创建,他是一个知名的开源开发者,贡献了大量的 Node.js 和前端工具。`neat-csv` 的设计目标是提供高效且...
在这个"JavaScript_快速CSV解析器在5KB分钟。.zip"压缩包中,我们可能找到了一个高效的JavaScript库,用于解析逗号分隔值(CSV)文件,这是数据交换和存储的常见格式。 CSV文件是简单的文本文件,其中的数据以逗号...
一个基于 Microsoft 的简单 CSV 解析器一个基于 Microsoft 的简单 CSV 解析器一个基于 Microsoft 的简单 CSV 解析器一个基于 Microsoft 的简单 CSV 解析器一个基于 Microsoft 的简单 CSV 解析器一个基于 Microsoft ...
SwiftCSV 是 CSV 解析器封装。 用法: id,name,age 1,Alice,18 2,Bob,19 3,Charlie,20 访问行和列的数据: let csvURL = NSURL(string: "users.csv") let csv = CSV(contentsOfURL: url) // Rows...
这个“csv文件解析小工具”是专为处理这类文件而设计的,允许用户直接运行并解析CSV内容。 解析CSV文件的主要挑战在于处理各种边缘情况,例如: 1. **字段内包含逗号**:当某个字段值本身含有逗号时,通常会用双...
"csv解析工具"是专为处理这种格式而设计的软件,能够高效地读取、编辑和分析CSV文件。 在电子商务领域,如淘宝和拍拍,商家经常需要处理大量的商品数据,这些数据通常以CSV格式导出,以便进行批量操作,如库存管理...
这个库提供了一系列方法来帮助我们方便地解析和生成CSV数据。 `javacsv`库由Jonathan Leffler开发,它允许开发者通过简单的API读取和写入CSV文件。在使用`javacsv`之前,你需要将`javacsv.jar`添加到你的项目类路径...
简单的Csv解析器一个简单的CSV分析器,用于将csv文件转换为对象列表并创建csv文件。产品特点分隔文件解析转换为可用的C#对象绑定到标题大文件处理安装包装经理 Install-Package SimpleCsvParser.Core.NET CLI ...
Rapidcsv的目标是为C++开发者提供一个轻量级、快速且易于集成的解决方案,以满足他们的CSV解析需求。 该库支持多种操作系统,包括Windows、macOS和Linux,这得益于C++的跨平台特性。此外,它还兼容C++11标准及以上...
一个简单的基于流或对象的csv解析和创建C ++库。 使用该库,您可以将CSV文件流式传输到对象中,或者将CSV行作为字符串添加到对象中,并获得具有已解析数据的双端队列对象。 数据可以从对象中流式传输,也可以从成员...
Scala CSV解析器库,如其名所示,是一个专门用于处理CSV(逗号分隔值)文件的工具,尤其适用于Scala编程环境。CSV是一种常见的数据交换格式,由于其简单性和广泛支持,被广泛应用在数据导入、导出以及数据分析任务中...
csv2go 用于将 CSV 文件解析为 JavaScript 对象的小型库。 用户可以传入一个描述 csv 列和预期对象之间关系的模式, csv2go将为输入的每一行创建一个符合模式的对象。 csv2go支持将 csv 列映射到对象属性将 csv 列...
这个包非常好,能处理特殊字符和换行符的问题,自己写的话很容易在特殊字符和换行符上出问题,建议用高人写的jar包。
在Flex中,虽然没有内置的CSV解析器,但可以通过第三方库如csvlib-1.4.1来实现。这个库提供了API,帮助开发者轻松地读取和写入CSV文件。例如,`CSVReader`类可以用来逐行读取CSV文件,`CSVWriter`类则用于将数据...
在CSV解析器中,FSM可以帮助我们识别和处理文件中的不同部分,如字段、记录和分隔符。 以下是这个CSV文件解析器的一些关键知识点: 1. 文件读取:使用C++的`fstream`库来读取和处理CSV文件。`ifstream`对象用于...