【一文了解】C#的StringSplitOptions枚举

目录

C#的StringSplitOptions枚举

1.StringSplitOptions枚举的常用成员

2.关键区别:用示例对比三种行为

2.1.StringSplitOptions.None(默认)

2.2.StringSplitOptions.RemoveEmptyEntries

[2.3.StringSplitOptions.TrimEntries(.NET 5+)](#2.3.StringSplitOptions.TrimEntries(.NET 5+))

3.常见使用场景

3.1.处理用户输入的标签(可能有连续逗号或空格)StringSplitOptions.TrimEntries

3.2.解析固定格式的配置(需保留空值位置)StringSplitOptions.None

3.3.读取CSV文件的字段(忽略空行但保留空白字段)StringSplitOptions.RemoveEmptyEntries

4.注意事项

4.1.TrimEntries的兼容性

4.2.多分隔符场景同样适用

5.总结


本篇文章来分享一下C#的StringSplitOptions枚举,StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为 ,核心作用是处理分割后产生的"空字符串"或"空白字符串",让开发者能精确控制分割结果的格式。

C#的StringSplitOptions枚举

1.StringSplitOptions枚举的常用成员

|--------------------|-------------------------------------|-----------------------------------|
| 枚举值 | 含义描述 | 适用场景 |
| None | 保留所有分割结果,包括空字符串("")和空白字符串(" ")。 | 需要完整保留分割节点(如解析固定格式协议数据,空值有特殊含义)。 |
| RemoveEmptyEntries | 移除纯空字符串(""),但保留含空白的字符串(如 " ")。 | 分割后需忽略空值,但保留空白内容(如 CSV 中空白字段有意义)。 |
| TrimEntries | 先去除每个分割结果的前后空白,再移除空字符串(.NET 5+ 新增)。 | 处理用户输入或格式不规范的文本(自动清理空格)。 |

2.关键区别:用示例对比三种行为

假设存在一个待分割的字符串:"apple,, banana, , orange"(包含连续逗号、带空格的内容、纯空白字符串),用','作为分隔符,三种选项的结果差异如下:

2.1.StringSplitOptions.None(默认)

保留所有分割结果,包括空字符串和空白字符串:

cs 复制代码
string input = "apple,, banana,  , orange";
string[] result = input.Split(',', StringSplitOptions.None);

//结果(5个元素):
//["apple", "", " banana", "  ", " orange"]

2.2.StringSplitOptions.RemoveEmptyEntries

移除纯空字符串(""),但保留带空白的字符串(" banana"、" "):

cs 复制代码
string[] result = input.Split(',', StringSplitOptions.RemoveEmptyEntries);

//结果(4个元素):
//["apple", " banana", "  ", " orange"]

2.3.StringSplitOptions.TrimEntries(.NET 5+)

先修剪每个结果的前后空白,再移除空字符串:

cs 复制代码
string[] result = input.Split(',', StringSplitOptions.TrimEntries);

//步骤1:修剪每个分割结果的空白
//["apple", "", "banana", "", "orange"]
//步骤2:移除空字符串
//最终结果(3个元素):["apple", "banana", "orange"]

3.常见使用场景

3.1.处理用户输入的标签(可能有连续逗号或空格)StringSplitOptions.TrimEntries

用户输入:"C#, Java,, Python ",希望得到干净的字符串:

cs 复制代码
string input = "C#,  Java,, Python  ";
//先按逗号分割,再修剪空白并移除空值
string[] tags = input.Split(',', StringSplitOptions.TrimEntries);
//结果:["C#", "Java", "Python"]

3.2.解析固定格式的配置(需保留空值位置)StringSplitOptions.None

配置字符串:"100,,true, "(位置2为必填空值,位置4为空白标记),需保留所有位置信息:

cs 复制代码
string config = "100,,true,  ";
//保留所有结果,不删除空值或空白
string[] configValues = config.Split(',', StringSplitOptions.None);
//结果:["100", "", "true", "  "](后续可根据位置解析含义)

3.3.读取CSV文件的字段(忽略空行但保留空白字段)StringSplitOptions.RemoveEmptyEntries

CSV行:"Alice,,30, New York "(中间有必填空字段):

cs 复制代码
string csvLine = "Alice,,30,  New York ";
//移除纯空字符串,但保留带空白的字段(如"  New York ")
string[] fields = csvLine.Split(',', StringSplitOptions.RemoveEmptyEntries);
//结果:["Alice", "30", "  New York "]

4.注意事项

4.1.TrimEntries的兼容性

该成员仅在.NET5、.NETCore3.0+及.NETFramework4.8+中可用,低版本需手动处理(先分割,再用Trim()修剪每个元素,最后过滤空值)。

cs 复制代码
string[] result = input.Split(',')
                       .Select(s => s.Trim())
                       .Where(s => !string.IsNullOrEmpty(s))
                       .ToArray();

4.2.多分隔符场景同样适用

不仅支持单个分隔符,也支持多个分隔符(如按,和;分割):

cs 复制代码
string input = "apple; banana,, orange";
string[] result = input.Split(new[] { ',', ';' }, StringSplitOptions.TrimEntries);
//结果:["apple", "banana", "orange"]

5.总结

StringSplitOptions是控制Split()方法结果格式的核心枚举,选择哪个成员取决于业务需求,合理使用该枚举能避免后续对分割结果的繁琐处理,让代码更简洁、健壮。

需完整保留所有分割结果(包括空值)→用None;

需移除纯空值但保留空白→用RemoveEmptyEntries;

需清理空白并移除空值(.NET5+)→用TrimEntries。

好了,本次的分享到这里就结束啦,希望对你有所帮助~

相关推荐
Hilaku2 分钟前
一个函数超过20行? 聊聊我的函数式代码洁癖
前端·javascript·架构
白兰地空瓶6 分钟前
# 从对象字面量到前端三剑客:JavaScript 为何是最具表现力的脚本语言?
前端
vivo互联网技术19 分钟前
vivo 前端三剑客发展历程及原理揭秘
前端
懒鸟一枚20 分钟前
Java 常见加密算法用法详解
java·开发语言
嵌入式-老费21 分钟前
Easyx图形库应用(lua中的函数回调)
开发语言·lua
喜欢吃燃面1 小时前
算法中的链表结构
开发语言·c++·学习·算法
十五年专注C++开发1 小时前
Fruit框架:C++依赖注入解决方案
开发语言·c++·依赖注入·fruit框架
华仔啊1 小时前
35岁程序员失业了,除了送外卖,还能做什么?
前端·后端·程序员
Lovely Ruby1 小时前
七日 Go 的自学笔记 (一)
开发语言·笔记·golang