删除一个字符,然后加上数字,删除下一​​个,依此类推

时间:2019-03-14 12:35:33

标签: c# database

我正在尝试在C#中执行以下操作: 我有一个包含以下数据的字符串(这是一个可用的最长字符串的示例,它是从数据库中提取的,根据我选择的ID,数据库可以在字符串中返回不同的数字): |1|,|2|,|3|,|4|,|5|,|6|,|7|,|8|,|9|,|10|,|11|,|12|,|13|,|14|,|15|,|16|,|17|,|18|,|19|,|20|,|21|,|22|,|23|,|24|,|25|,|26|,|27|,|28|,|29|,|30|,|31|,|32|,|33|,|34|,|35|,|36|,|37|,|38|,|39|,|40|,|41|,|42|,|43|,|44|,|45|,|46|,|47|,|48|,|49|,|50|,|51|,|52|,|53|

这些是一年中的几周,我想删除每个“ |”和“,”并将每个整数存储在列表中的一个索引中,如下所示:

`
weekList[0] = 1
weekList[1] = 2
weekList[2] = 3
weekList[3] = 4
weekList[4] = 5
.
.
.
weekList[49] = 50
weekList[50] = 51
weekList[51] = 52
weekList[52] = 53
`

如何实现?我已经阅读了很多有关正则表达式的信息,但根本找不到解决此问题的方法...

4 个答案:

答案 0 :(得分:1)

1)用逗号(,)分割字符串。

2)用字符空间()和管道(|)分割字符串中的每个元素

3)将每个元素解析为int

string str = "| 1 |,| 2 |,| 3 |,| 4 |,| 5 |,| 6 |,| 7 |,| 8 |,| 9 |,| 10 |,| 11 |,| 12 |,| 13 |,| 14 |,| 15 |,| 16 |,| 17 |,| 18 |,| 19 |,| 20 |,| 21 |,| 22 |,| 23 |,| 24 |,| 25 |,| 26 |,| 27 |,| 28 |,| 29 |,| 30 |,| 31 |,| 32 |,| 33 |,| 34 |,| 35 |,| 36 |,| 37 |,| 38 |,| 39 |,| 40 |,| 41 |,| 42 |,| 43 |,| 44 |,| 45 |,| 46 |,| 47 |,| 48 |,| 49 |,| 50 |,| 51 |,| 52 |,| 53 |";

int[] arr = str.Split(',')
               .Select(x => x.Trim(new char[] { ' ', '|' }))
               .Select(x => int.Parse(x))
               .ToArray();

现在,arr是您的整数数组。

Online Demo

替代:

1)删除管道(|)和空格()。

2)以逗号(,)分隔。

3)将每个分割的字符串解析为int。

int[] arr = str.Replace("|", "")
               .Replace(" ", "")
               .Split(',')
               .Select(x => int.Parse(x))
               .ToArray();

Online Demo

答案 1 :(得分:1)

这将为您工作:

        string str = "|1|,|2|,|3|,|4|,|5|,|6|,|7|,|8|,|9|,|10|,|11|,|12|,|13|,|14|,|15|,|16|,|17|,|18|,|19|,|20|,|21|,|22|,|23|,|24|,|25|,|26|,|27|,|28|,|29|,|30|,|31|,|32|,|33|,|34|,|35|,|36|,|37|,|38|,|39|,|40|,|41|,|42|,|43|,|44|,|45|,|46|,|47|,|48|,|49|,|50|,|51|,|52|,|53|";
        str = str.Replace("|", "");

        string[] subStrings = str.Split(',');
        int[] ints = new int[subStrings.Length];
        for (int i = 0; i < subStrings.Length; i++)
        {
            ints[i] = Convert.ToInt32(subStrings[i]);
        } 

答案 2 :(得分:0)

我想出了您所要求的正则表达式方法。 首先,您必须使用Regex模式 \ d + 查找所有数字,此模式匹配一​​个或多个数字。使用Regexstorm tested测试您的正则表达式。遍历所有匹配项并分配给您的数组。

这是我提出的C#交互式示例:

string input = "| 1 |,| 2 |,| 3 |,| 4 |,| 5 |,| 6 |,| 7 |,| 8 |,| 9 |,| 10 |,| 11 |,| 12 |,| 13 |,| 14 |,| 15 |,| 16 |,| 17 |,| 18 |,| 19 |,| 20 |,| 21 |,| 22 |,| 23 |,| 24 |,| 25 |,| 26 |,| 27 |,| 28 |,| 29 |,| 30 |,| 31 |,| 32 |,| 33 |,| 34 |,| 35 |,| 36 |,| 37 |,| 38 |,| 39 |,| 40 |,| 41 |,| 42 |,| 43 |,| 44 |,| 45 |,| 46 |,| 47 |,| 48 |,| 49 |,| 50 |,| 51 |,| 52 |,| 53 |";
MatchCollection matches = Regex.Matches(input, @"\d+");
int[] values = new int[matches.Count];
for (int i = 0; i < matches.Count; i++)
    values[i] = Convert.ToInt32(matches[i].Value);

答案 3 :(得分:0)

private void button1_Click(obj sender,EventArgs e)
{
String str = "|1|,|2|,|3|,|4|...";
char[] ch =str.ToArray(),weekList=new char[ch.Length];
Int index=1;
for (int i=1;i < ch.Length ;i++)
{
if(index < ch.length-1)
{
weekList[i] = ch[index];
Index += 4;
}
}
MessageBox.Show(weekList[0]);//1
MessageBox.Show(weekList[9]);//10
}