C# 如何在字母数字字符串中插入字符
我是C#的新手。我有一个短格式和一个长格式的客户端代码。短格式是一些字母字符和一些数字字符(ABC12),而长格式总是15个字符长,字母和数字部分之间的空格用零填充(ABC000000000012)。我需要能够从短格式转换为长格式。下面的代码是我如何让它工作的——这是最好的方法吗C# 如何在字母数字字符串中插入字符,c#,alphanumeric,C#,Alphanumeric,我是C#的新手。我有一个短格式和一个长格式的客户端代码。短格式是一些字母字符和一些数字字符(ABC12),而长格式总是15个字符长,字母和数字部分之间的空格用零填充(ABC000000000012)。我需要能够从短格式转换为长格式。下面的代码是我如何让它工作的——这是最好的方法吗 public string ExpandCode(string s) { // s = "ABC12" int i = 0; char c; bool foundDigit = fals
public string ExpandCode(string s)
{
// s = "ABC12"
int i = 0;
char c;
bool foundDigit = false;
string o = null;
while (foundDigit == false)
{
c = Convert.ToChar(s.Substring(i, 1));
if (Char.IsDigit(c))
{
foundDigit = true;
o = s.Substring(0, i) + new String('0', 15-s.Length) + s.Substring(i,s.Length-i);
}
i += 1;
}
return (o); //o = "ABC000000000012"
}
您的代码基本上是正确的,但是可能会很慢,因为
String.Substring(…)
每次调用时都会创建一个新字符串
我还建议您使用.NET api的内置函数来完成任务,这可以使编码更加容易:
private char[] numbers = new char[]{'1', '2', '3', '4', '5', '6', '7', '8', '9', '0'};
public string ExpandCode(string s)
{
//Find the first numeric char.
int index = s.IndexOfAny(numbers);
//Insert zeros and return the result.
return s.Insert(index, new String('0', 15 - s.Length));
}
您的代码基本上是正确的,但是可能会很慢,因为
String.Substring(…)
每次调用时都会创建一个新字符串
我还建议您使用.NET api的内置函数来完成任务,这可以使编码更加容易:
private char[] numbers = new char[]{'1', '2', '3', '4', '5', '6', '7', '8', '9', '0'};
public string ExpandCode(string s)
{
//Find the first numeric char.
int index = s.IndexOfAny(numbers);
//Insert zeros and return the result.
return s.Insert(index, new String('0', 15 - s.Length));
}
您可以使用string.Format()来处理填充。我使用正则表达式(并不是以一种非常健壮的方式)来解析字母和数字,但是您可以用另一种方法更有效地解析字母和数字
关键的一点是,我们动态地计算出需要多少个零,然后使用格式字符串X:dY
,其中X=格式序号,Y=要填充的零的数量
var match = Regex.Match("ABC12", @"([^\d]+)(\d+)");
var letters = match.Groups[1].Value;
var numbers = int.Parse(match.Groups[2].Value);
var formatString = "{0}{1:d" + (15 - letters.Length) + "}";
var longForm = string.Format(formatString, letters, numbers);
您可以使用string.Format()来处理填充。我使用正则表达式(并不是以一种非常健壮的方式)来解析字母和数字,但是您可以用另一种方法更有效地解析字母和数字
关键的一点是,我们动态地计算出需要多少个零,然后使用格式字符串X:dY
,其中X=格式序号,Y=要填充的零的数量
var match = Regex.Match("ABC12", @"([^\d]+)(\d+)");
var letters = match.Groups[1].Value;
var numbers = int.Parse(match.Groups[2].Value);
var formatString = "{0}{1:d" + (15 - letters.Length) + "}";
var longForm = string.Format(formatString, letters, numbers);
看看这个:
public string ExpandCode(string s)
{
var builder = new StringBuilder(s);
var index = Array.FindIndex(s.ToArray(), x => char.IsDigit(x));
while (builder.Length < 15)
{
builder.Insert(index, '0');
}
return builder.ToString();
}
公共字符串扩展代码(字符串s)
{
var builder=新的StringBuilder;
var index=Array.FindIndex(s.ToArray(),x=>char.IsDigit(x));
while(builder.Length<15)
{
插入(索引“0”);
}
返回builder.ToString();
}
我假设字符串总是字母->数字(如“abc123”或“ab1234”)。看看这个:
public string ExpandCode(string s)
{
var builder = new StringBuilder(s);
var index = Array.FindIndex(s.ToArray(), x => char.IsDigit(x));
while (builder.Length < 15)
{
builder.Insert(index, '0');
}
return builder.ToString();
}
公共字符串扩展代码(字符串s)
{
var builder=新的StringBuilder;
var index=Array.FindIndex(s.ToArray(),x=>char.IsDigit(x));
while(builder.Length<15)
{
插入(索引“0”);
}
返回builder.ToString();
}
我假设字符串总是字母->数字(如“abc123”或“ab1234”)。越纯,速度越快
public static string ExpandCode4(string s)
{
char[] res = new char[15];
int ind = 0;
for (int i = 0; i < s.Length && s[i] >= 'A'; i++)
res[ind++] = s[i];
int tillDigit = ind;
for (int i = 0; i < 15 - s.Length; i++)
res[ind++] = '0';
for (int i = 0; i < s.Length - tillDigit; i++)
res[ind++] = s[tillDigit + i];
return new string(res);
}
公共静态字符串ExpandCode4(字符串s)
{
char[]res=新字符[15];
int ind=0;
对于(int i=0;i='A';i++)
res[ind++]=s[i];
int-digit=ind;
对于(int i=0;i<15-s.长度;i++)
res[ind++]='0';
对于(int i=0;i
所有答案的基准如下:
internal class Program
{
private static void Main(string[] args)
{
var inputs = new List<string>();
for (int i = 0; i < 10000000; i++)
{
inputs.Add("ABC1234");
}
var n1 = DateTime.Now;
inputs.ForEach(i => ExpandCode1(i));
var r1 = (DateTime.Now - n1).Ticks;
var n2 = DateTime.Now;
inputs.ForEach(i => ExpandCode2(i));
var r2 = (DateTime.Now - n2).Ticks;
var n3 = DateTime.Now;
inputs.ForEach(i => ExpandCode3(i));
var r3 = (DateTime.Now - n3).Ticks;
var n4 = DateTime.Now;
inputs.ForEach(i => ExpandCode4(i));
var r4 = (DateTime.Now - n4).Ticks;
var results = new List<Result>()
{
new Result() {Name = "1", Ticks = r1},
new Result() {Name = "2", Ticks = r2},
new Result() {Name = "3", Ticks = r3},
new Result() {Name = "4", Ticks = r4}
};
results.OrderBy(r => r.Ticks).ToList().ForEach(Console.WriteLine);
Console.ReadKey();
}
public static string ExpandCode4(string s)
{
char[] res = new char[15];
int ind = 0;
for (int i = 0; i < s.Length && s[i] >= 'A'; i++)
res[ind++] = s[i];
int tillDigit = ind;
for (int i = 0; i < 15 - s.Length; i++)
res[ind++] = '0';
for (int i = 0; i < s.Length - tillDigit; i++)
res[ind++] = s[tillDigit + i];
return new string(res);
}
public static string ExpandCode1(string s)
{
char[] numbers = new char[] { '1', '2', '3', '4', '5', '6', '7', '8', '9', '0' };
//Find the first numeric char.
int index = s.IndexOfAny(numbers);
//Insert zeros and return the result.
return s.Insert(index, new String('0', 15 - s.Length));
}
public static string ExpandCode2(string s)
{
var builder = new StringBuilder(s);
var index = Array.FindIndex(s.ToArray(), x => char.IsDigit(x));
while (builder.Length < 15)
{
builder.Insert(index, '0');
}
return builder.ToString();
}
public static string ExpandCode3(string s)
{
var match = Regex.Match(s, @"([^\d]+)(\d+)");
var letters = match.Groups[1].Value;
var numbers = int.Parse(match.Groups[2].Value);
var formatString = "{0}{1:d" + (15 - letters.Length) + "}";
var longForm = string.Format(formatString, letters, numbers);
return longForm;
}
}
public class Result
{
public long Ticks { get; set; }
public string Name { get; set; }
public override string ToString()
{
return Name + " - " + Ticks;
}
}
内部类程序
{
私有静态void Main(字符串[]args)
{
变量输入=新列表();
对于(int i=0;i<10000000;i++)
{
输入。添加(“ABC1234”);
}
var n1=DateTime.Now;
inputs.ForEach(i=>ExpandCode1(i));
var r1=(DateTime.Now-n1);
var n2=DateTime.Now;
ForEach(i=>ExpandCode2(i));
var r2=(DateTime.Now-n2);
var n3=DateTime.Now;
ForEach(i=>ExpandCode3(i));
var r3=(DateTime.Now-n3).Ticks;
var n4=DateTime.Now;
ForEach(i=>ExpandCode4(i));
var r4=(DateTime.Now-n4).Ticks;
var results=新列表()
{
新结果(){Name=“1”,Ticks=r1},
新结果(){Name=“2”,Ticks=r2},
新结果(){Name=“3”,Ticks=r3},
新结果(){Name=“4”,Ticks=r4}
};
results.OrderBy(r=>r.Ticks).ToList().ForEach(Console.WriteLine);
Console.ReadKey();
}
公共静态字符串ExpandCode4(字符串s)
{
char[]res=新字符[15];
int ind=0;
对于(int i=0;i='A';i++)
res[ind++]=s[i];
int-digit=ind;
对于(int i=0;i<15-s.长度;i++)
res[ind++]='0';
对于(int i=0;ichar.IsDigit(x));
while(builder.Length<15)
{
插入(索引“0”);
}
返回builder.ToString();
}
公共静态字符串ExpandCode3(字符串s)
{
var match=Regex.match,@“([^\d]+)(\d+);
var letters=match.Groups[1]。值;
var numbers=int.Parse(match.Groups[2].Value);
var formatString=“{0}{1:d”+(15个字母.Length)+“}”;
var longForm=string.Format(格式化字符串、字母、数字);
返回长格式;
}
}
公开课成绩
{
公共长记号{get;set;}
公共字符串名称{get;set;}
公共重写字符串ToString()
{
返回名称+“-”+记号;
}
}
越纯,速度越快
public static string ExpandCode4(string s)
{
char[] res = new char[15];
int ind = 0;
for (int i = 0; i < s.Length && s[i] >= 'A'; i++)
res[ind++] = s[i];
int tillDigit = ind;
for (int i = 0; i < 15 - s.Length; i++)
res[ind++] = '0';
for (int i = 0; i < s.Length - tillDigit; i++)
res[ind++] = s[tillDigit + i];
return new string(res);
}
公共静态字符串ExpandCode4(字符串s)
{
char[]res=新字符[15];
int