可能是重复问题:
正则表达式,按大写字母拆分字符串,但忽略TLA
我有一个字符串,它由多个单词组成,每个单词的首字母都大写。
例如: SeveralWordsString
使用C#,如何以聪明的方式将字符串拆分为 "Several Words String"?
谢谢!
可能是重复问题:
正则表达式,按大写字母拆分字符串,但忽略TLA
我有一个字符串,它由多个单词组成,每个单词的首字母都大写。
例如: SeveralWordsString
使用C#,如何以聪明的方式将字符串拆分为 "Several Words String"?
谢谢!
使用这个正则表达式(我忘记从哪个stackoverflow答案上获取的,现在会搜索一下):
public static string ToLowercaseNamingConvention(this string s, bool toLowercase)
{
if (toLowercase)
{
var r = new Regex(@"
(?<=[A-Z])(?=[A-Z][a-z]) |
(?<=[^A-Z])(?=[A-Z]) |
(?<=[A-Za-z])(?=[^A-Za-z])", RegexOptions.IgnorePatternWhitespace);
return r.Replace(s, "_").ToLower();
}
else
return s;
}
我在这个项目中使用它:http://www.ienablemuch.com/2010/12/intelligent-brownfield-mapping-system.html
[编辑]
我现在找到了:如何将Java中的CamelCase转换为人类可读名称?
很好地分割了“TodayILiveInTheUSAWithSimon”,“ Today”前面没有空格:
using System;
using System.Text.RegularExpressions;
namespace TestSplit
{
class MainClass
{
public static void Main (string[] args)
{
Console.WriteLine ("Hello World!");
var r = new Regex(@"
(?<=[A-Z])(?=[A-Z][a-z]) |
(?<=[^A-Z])(?=[A-Z]) |
(?<=[A-Za-z])(?=[^A-Za-z])", RegexOptions.IgnorePatternWhitespace);
string s = "TodayILiveInTheUSAWithSimon";
Console.WriteLine( "YYY{0}ZZZ", r.Replace(s, " "));
}
}
}
输出:
YYYToday I Live In The USA With SimonZZZ
string[] SplitCamelCase(string source) {
return Regex.Split(source, @"(?<!^)(?=[A-Z])");
}
示例:
return string.Join(" ", Regex.Split(value, @"(?<!^)(?=[A-Z](?![A-Z]|$))"));
这段代码。 - śmiglidiglipublic static string SplitCamelCase(this string input, string delimeter = " ") { return input.Any(char.IsUpper) ? string.Join(delimeter, Regex.Split(input, "(?<!^)(?=[A-Z])")) : input; }
。这允许您指定分隔符,并且如果输入字符串不包含任何大写字母,则返回输入字符串而不执行RegEx。示例用法:var s = myString.SplitCamelCase();
或 var s = myString.SplitCamelCase(" ,");
。 - AndersCamelCase
和 pascalCase
。 - Themelis您只需循环遍历字符,并在需要时添加空格:
string theString = "SeveralWordsString";
StringBuilder builder = new StringBuilder();
foreach (char c in theString) {
if (Char.IsUpper(c) && builder.Length > 0) builder.Append(' ');
builder.Append(c);
}
theString = builder.ToString();
public static IEnumerable<string> SplitOnCapitals(string text)
{
Regex regex = new Regex(@"\p{Lu}\p{Ll}*");
foreach (Match match in regex.Matches(text))
{
yield return match.Value;
}
}
这将正确处理 Unicode。
string str1 = "SeveralWordsString";
string newstring = "";
for (int i = 0; i < str1.Length; i++)
{
if (char.IsUpper(str1[i]))
newstring += " ";
newstring += str1[i].ToString();
}
StringBuilder
而不是创建大量的字符串。 - Andrew