我一直在使用Split()
方法来分割字符串。但是如果你在string.Split()
中为条件设置一些字符,那么这项工作。有没有办法在看到Uppercase
时分割字符串?
是否可以从一些不分离的字符串中获取几个单词,如:
DeleteSensorFromTemplate
结果字符串如下:
Delete Sensor From Template
答案 0 :(得分:15)
使用Regex.split
string[] split = Regex.Split(str, @"(?<!^)(?=[A-Z])");
答案 1 :(得分:3)
如果你不喜欢RegEx并且你真的只想插入缺失的空格,那么这也可以完成这项工作:
public static string InsertSpaceBeforeUpperCase(this string str)
{
var sb = new StringBuilder();
char previousChar = char.MinValue; // Unicode '\0'
foreach (char c in str)
{
if (char.IsUpper(c))
{
// If not the first character and previous character is not a space, insert a space before uppercase
if (sb.Length != 0 && previousChar != ' ')
{
sb.Append(' ');
}
}
sb.Append(c);
previousChar = c;
}
return sb.ToString();
}
答案 2 :(得分:0)
使用正则表达式的另一种方法:
public static string SplitCamelCase(string input)
{
return System.Text.RegularExpressions.Regex.Replace(input, "([A-Z])", " $1", System.Text.RegularExpressions.RegexOptions.Compiled).Trim();
}
答案 3 :(得分:0)
我对此很有趣,并提出了一个按大小写拆分的函数,以及将大写字母(后面假设为大写字母)和数字分组的方法。
示例:
输入->“ TodayIUpdated32UPCCodes”
输出->“今天我更新了32个UPC代码”
代码(请原谅我使用的时髦符号)...
public string[] SplitByCase(this string s) {
var ʀ = new List<string>();
var ᴛ = new StringBuilder();
var previous = SplitByCaseModes.None;
foreach(var ɪ in s) {
SplitByCaseModes mode_ɪ;
if(string.IsNullOrWhiteSpace(ɪ.ToString())) {
mode_ɪ = SplitByCaseModes.WhiteSpace;
} else if("0123456789".Contains(ɪ)) {
mode_ɪ = SplitByCaseModes.Digit;
} else if(ɪ == ɪ.ToString().ToUpper()[0]) {
mode_ɪ = SplitByCaseModes.UpperCase;
} else {
mode_ɪ = SplitByCaseModes.LowerCase;
}
if((previous == SplitByCaseModes.None) || (previous == mode_ɪ)) {
ᴛ.Append(ɪ);
} else if((previous == SplitByCaseModes.UpperCase) && (mode_ɪ == SplitByCaseModes.LowerCase)) {
if(ᴛ.Length > 1) {
ʀ.Add(ᴛ.ToString().Substring(0, ᴛ.Length - 1));
ᴛ.Remove(0, ᴛ.Length - 1);
}
ᴛ.Append(ɪ);
} else {
ʀ.Add(ᴛ.ToString());
ᴛ.Clear();
ᴛ.Append(ɪ);
}
previous = mode_ɪ;
}
if(ᴛ.Length != 0) ʀ.Add(ᴛ.ToString());
return ʀ.ToArray();
}
private enum SplitByCaseModes { None, WhiteSpace, Digit, UpperCase, LowerCase }