分开一个长串

时间:2012-01-18 12:14:24

标签: c# .net

A具有以下输入字符串:

string input =
   "Ta005000000000000000000Tb001700000000000000000Sa005000000000000000000" +
   "Sb002500000000000000000F     00000000000000000I     00000000000000000N" +
   "     00000000000000000FS    00000000000000000IS    00000000000000000NS" +
   "    00000000000000000";

我需要将此字符串分成几部分,但内容差异很大。

必须将此字符串放入如下列表中:

[0] "Ta005000000000000000000"
[1] "Tb001700000000000000000"
[2] "Sa005000000000000000000"
[3] "Sb002500000000000000000"
[4] "00000000000000000I"
[5] "00000000000000000N"
[6] "0000000000000000FS"
[7] "0000000000000000IS"
[8] "0000000000000000NS"
[9] "000000000000000000"

在这种情况下我唯一知道的是字符串的最大长度为23。 所以,在这个例子中,我需要分离字符串返回的fisrt部分的'T'或'S'。或者,如果没有出现这些字符,则用空格分隔(它发生在我的字符串返回的最后一部分)。我这样做了:

var linq = test.Split(new[] { 'T', 'S', ' ', '{', '}' }, StringSplitOptions.RemoveEmptyEntries).ToList();

我的“test”是一个包含返回字符的StrintBuilder。通过这样做,我可以将我的列表分开,但在这种情况下我丢失了一个非常重要的信息,即“T”和“S”。

嗯,不知道它是否清楚,但它似乎很简单,让我头疼不已。

Obs:其他问题是,例如:“0000000000000000FS”,在这部分字符串中我需要将“FS”保持在一起。

感谢您的关注,

3 个答案:

答案 0 :(得分:6)

拆分删除拆分字符。只需将这些替换为如下所示插入空格,然后在空格字符处分割:

var linq = myRates.Replace("T"," T").Replace("S"," S").Split(new[] { ' ', '{', '}' }, StringSplitOptions.RemoveEmptyEntries).ToList();

修改

这个规则非常复杂。也许这解决了你的问题。

string input =
   "Ta005000000000000000000Tb001700000000000000000Sa005000000000000000000" +
   "Sb002500000000000000000F     00000000000000000I     00000000000000000" +
   "N     00000000000000000FS    00000000000000000IS    00000000000000000" +
   "NS    00000000000000000";

第一步:分开''

string[] spaceSplit = input.Split(' ', StringSplitOptions.RemoveEmptyEntries);

现在spaceSplit看起来像这样:

[0] "Ta005000000000000000000Tb001700000000000000000Sa005000000000000000000Sb002500000000000000000F"
[1] "00000000000000000I"
[2] "00000000000000000N"
[3] "0000000000000000FS"
[4] "0000000000000000IS"
[5] "0000000000000000NS"
[6] "000000000000000000"

现在,如果长度超过23个字符,则按“T”和“S”

分割每一行
List<string> temp = new List<string>();
foreach(string s in spaceSplit)
  if (s.Length>23)
    temp.AddRange(s.Replace("T", " T").Replace("S", " S").Split(' '));
  else
    temp.Add(s);

temp.ToArray()收益

[0] "Ta005000000000000000000"
[1] "Tb001700000000000000000"
[2] "Sa005000000000000000000"
[3] "Sb002500000000000000000F"
[4] "00000000000000000I"
[5] "00000000000000000N"
[6] "0000000000000000FS"
[7] "0000000000000000IS"
[8] "0000000000000000NS"
[9] "000000000000000000"

var linq = (from s in temp select s.Substring(0,23)).ToList();

etvoilà,linq是你想要的数组。但对于其他输入组合,这种“算法”可能会破坏。

答案 1 :(得分:3)

这样的东西?

string[] separatedString = Regex.Split(s, @"(?=[TS ])") ;

然后你只需删除“空”元素,如果你想

答案 2 :(得分:1)

使用正则表达式执行此操作:

string[] parts = Regex.Split(test, @"(?<=[TS\s\{\})");

我不确定花括号是否格式正确。