gpt4 book ai didi

C# - 使用正则表达式将数据排序到/从列表框

转载 作者:太空宇宙 更新时间:2023-11-03 11:34:37 25 4
gpt4 key购买 nike

我有一个包含数据的文件,我想将其分成三个不同的列表框。我希望第一个 ListBox 包含所有数据(从文本文档中读取的每一行数据都有一个新的列表项)。

主列表框:

D1
D2
C9
R7
R1
C130
D99
Q9

第二个 ListBox:(在使用正则表达式匹配以 D 开头的值之后)

D1
D2
D99

第三个列表框:(在使用正则表达式匹配以 C 开头的值之后)

C9
C130

在为 SECONDTHIRD 列表框匹配这些值后,

New Main ListBox 将如下所示:

R7
R1
Q9

代码

    static List<string> findPackagePlacementOneType(List<string> list)
{
// Creates a new list to return with new format.
var result = new List<string>();

// Checks each line in the list.
foreach (var line in list)
{
// PLACEMENT ONE Regex
Match regexRES = Regex.Match(line, @"^.+(RES)");
Match regex0402 = Regex.Match(line, @"^.+(0402)");
Match regex0201 = Regex.Match(line, @"^.+(0201)");
Match regex0603 = Regex.Match(line, @"^.+(0603)");
Match regex0805 = Regex.Match(line, @"^.+(0805)");
Match regex1206 = Regex.Match(line, @"^.+(1206)");
Match regex1306 = Regex.Match(line, @"^.+(1306)");
Match regex1608 = Regex.Match(line, @"^.+(1608)");
Match regex3216 = Regex.Match(line, @"^.+(3216)");
Match regex2551 = Regex.Match(line, @"^.+(2551)");
Match regex1913 = Regex.Match(line, @"^.+(1913)");
Match regex1313 = Regex.Match(line, @"^.+(1313)");
Match regex2513 = Regex.Match(line, @"^.+(2513)");
Match regex5125 = Regex.Match(line, @"^.+(5125)");
Match regex2525 = Regex.Match(line, @"^.+(2525)");
Match regex5619 = Regex.Match(line, @"^.+(5619)");
Match regex3813 = Regex.Match(line, @"^.+(3813)");
Match regex1508 = Regex.Match(line, @"^.+(1508)");
Match regex6431 = Regex.Match(line, @"^.+(6431)");
Match regex2512 = Regex.Match(line, @"^.+(2512)");
Match regex1505 = Regex.Match(line, @"^.+(1505)");
Match regex2208 = Regex.Match(line, @"^.+(2208)");
Match regex1005 = Regex.Match(line, @"^.+(1005)");
Match regex1010 = Regex.Match(line, @"^.+(1010)");
Match regex2010 = Regex.Match(line, @"^.+(2010)");
Match regex0505 = Regex.Match(line, @"^.+(0505)");
Match regex0705 = Regex.Match(line, @"^.+(0705)");
Match regex1020 = Regex.Match(line, @"^.+(1020)");
Match regex1812 = Regex.Match(line, @"^.+(1812)");
Match regex2225 = Regex.Match(line, @"^.+(2225)");
Match regex5764 = Regex.Match(line, @"^.+(5764)");
Match regex4532 = Regex.Match(line, @"^.+(4532)");
Match regex1210 = Regex.Match(line, @"^.+(1210)");
Match regex0816 = Regex.Match(line, @"^.+(0816)");
Match regex0363 = Regex.Match(line, @"^.+(0363)");
Match regexSOT = Regex.Match(line, @"^.+(SOT)");

if (regexRES.Success || regex0402.Success || regex0201.Success || regex0603.Success ||
regex0805.Success || regex1206.Success || regex1306.Success || regex1608.Success ||
regex3216.Success || regex2551.Success || regex1913.Success || regex1313.Success ||
regex2513.Success || regex5125.Success || regex2525.Success || regex5619.Success ||
regex3813.Success || regex1508.Success || regex6431.Success || regex2512.Success ||
regex1505.Success || regex2208.Success || regex1005.Success || regex1010.Success ||
regex2010.Success || regex0505.Success || regex0705.Success || regex1020.Success ||
regex1812.Success || regex2225.Success || regex5764.Success || regex4532.Success ||
regex1210.Success || regex0816.Success || regex0363.Success || regexSOT.Success)
{
result.Add(string.Join(" ", line));
}

else
result.Remove(line);
}

// Returns the new list so it can be formatted further.
return result;
}

// Finds the placement 2 package types.
static List<string> findPackagePlacementTwoType(List<string> list)
{
// Creates a new list to return with new format.
var result = new List<string>();

// Checks each line in the list.
foreach (var line in list)
{
// PLACEMENT TWO Regex
Match regexBGA = Regex.Match(line, @"^.+(BGA)");
Match regexSOP8 = Regex.Match(line, @"^.+(SOP8)");
Match regexQSOP = Regex.Match(line, @"^.+(QSOP)");
Match regexTQSOP = Regex.Match(line, @"^.+(TQSOP)");
Match regexSOIC16 = Regex.Match(line, @"^.+(SOIC16)");
Match regexSOIC12Plus = Regex.Match(line, @"^.+(SOIC12)");
Match regexSOIC8 = Regex.Match(line, @"^.+(SOIC8)");
Match regexSO8 = Regex.Match(line, @"^.+(SO8)");
Match regexSO08 = Regex.Match(line, @"^.+(SO08)");
Match regexCQFP = Regex.Match(line, @"^.+(CQFP)");
Match regexLCC = Regex.Match(line, @"^.+(LCC)");
Match regexLGA = Regex.Match(line, @"^.+(LGA)");
Match regexOSCCC = Regex.Match(line, @"^.+(OSCCC)");
Match regexPLCC = Regex.Match(line, @"^.+(PLCC)");
Match regexQFN = Regex.Match(line, @"^.+(QFN)");
Match regexQFP = Regex.Match(line, @"^.+(QFP)");
Match regexSOJ = Regex.Match(line, @"^.+(SOJ)");
Match regexSON = Regex.Match(line, @"^.+(SON)");

if (regexBGA.Success || regexSOP8.Success || regexQSOP.Success || regexTQSOP.Success ||
regexSOIC16.Success || regexSOIC12Plus.Success || regexSOIC8.Success || regexSO8.Success ||
regexSO08.Success || regexCQFP.Success || regexLCC.Success || regexLGA.Success ||
regexOSCCC.Success || regexPLCC.Success || regexQFN.Success || regexQFP.Success ||
regexSOJ.Success || regexSON.Success)
{
result.Add(string.Join(" ", line));
}

else
result.Remove(line);
}

// Returns the new list so it can be formatted further.
return result;
}

static List<string> findPackagePlacementChoiceType(List<string> list)
{
// Creates a new list to return with new format.
var result = new List<string>();

// Checks each line in the list.
foreach (var line in list)
{
// PLACEMENT CHOICE Regex
Match regexCAP = Regex.Match(line, @"^.+(CAP)");
Match regexIND = Regex.Match(line, @"^.+(IND)");
Match regexMELF = Regex.Match(line, @"^.+(MELF)");
Match regexDIOM = Regex.Match(line, @"^.+(DIOM)");
Match regexSOD = Regex.Match(line, @"^.+(SOD)");
Match regexSTO = Regex.Match(line, @"^.+(STO)");
Match regexTO = Regex.Match(line, @"^.+(TO)");

if (regexCAP.Success || regexIND.Success || regexMELF.Success || regexDIOM.Success ||
regexSOD.Success || regexSTO.Success || regexTO.Success)
{
result.Add(string.Join(" ", line));
}

else
result.Remove(line);
}

// Returns the new list so it can be formatted further.
return result;
}

问题

我目前有我的正则表达式,可以对文件进行排序并将文件分成三个单独的列表框。但是......我宁愿将数据放在其中一个列表框中,然后在匹配时从该列表框中排序/删除正确的正则表达式。

  • 我如何将 .txt 文档加载到列表框中(每一个新行都是列表框中的一个新项目),然后使用正则表达式遍历主列表框中的每一行以确定如果行进入不同的secondthird ListBox 或留在ma​​in ListBox

最佳答案

您可以将它们组合成一个,而不是多个正则表达式。

您也不需要调用 Regex.Match其次是 match.Success ;只需调用 Regex.IsMatch .

我不明白你为什么要使用 result.Remove(line) .您从未添加过不匹配的行,那么为什么需要删除它?

最后,我认为您不需要使方法特定于使用 List<string> .您可以通过指定 IEnumerable<string> 使其更通用.

我重写了第一个来演示原理:

static IEnumerable<string> findPackagePlacementOneType(IEnumerable<string> list)
{
return list.Where(line => Regex.IsMatch(line,
@"^.+(RES|0402|0201|0603|0805|1206|1306|1608|3216|2551|1913|1313|2513" +
@"|5125|2525|5619|3813|1508|6431|2512|1505|2208|1005|1010|2010|0505" +
@"|0705|1020|1812|2225|5764|4532|1210|0816|0363|SOT)"
));
}

如果你真的需要一个新的 List<string> , 你可以只添加 .ToList()在调用 findPackagePlacementOneType 后.

关于C# - 使用正则表达式将数据排序到/从列表框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6700967/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com