- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试获取一个字符串,其中包含一个编号列表,每个列表旁边都有数据项,并根据每个数字旁边的数据将它们分成多个字符串。我尝试使用正则表达式,但这导致了一些问题,因为一些数据是货币值(value),例如 £120,000.00。
示例数据为
先生测试测试
100,000.00 英镑
5 测试路,测试街
测试输入:
string testInput = "1. Mr Test Test 2. £100,000 3. 5 Test Road"
但是,编号列表可能会出现在字符串中的不同行上,因为字符串是使用 PDFBox
中的 PdfTextStripper
从 PDF 中提取的/p>
有什么方法可以准确拆分吗?
我最初是使用 indexof 并依赖下一个数据项标题作为停止点,但数据并不总是相同(15
点对一个,25
在另一个)。
想要的结果是:
string Name = "Mr Test Test";
string Money = "£100,000.00";
string Address = "5 Test Road, Test Street";
任何帮助将不胜感激
最佳答案
让我们实现一个简单的生成器;我们可以在循环中逐行查找:
代码:
private static IEnumerable<string> ParseListToLines(string value) {
int start = 0;
bool first = true;
for (int index = 1; ; ++index) {
string toFind = $"{index}.";
int next = value.IndexOf(toFind, start);
if (next < 0) {
yield return value.Substring(start);
break;
}
if (!first) // we don't return text before the 1st item
yield return value.Substring(start, next - start);
first = false;
start = next + toFind.Length;
}
}
演示:
string testInput = "1. Mr Test Test 2. £100,000 3. 5 Test Road";
string[] lines = ParseListToLines(testInput).ToArray();
// string Name = lines[0].Trim();
// string Money = lines[1].Trim();
// string Address = lines[2].Trim();
Console.Write(string.Join(Environment.NewLine, lines));
结果:
Mr Test Test
£100,000
5 Test Road
编辑更多演示,包含详细测试(项目内和项目外的新行;一位和两位数标记;文本 - **
-在初始 1.
标记之前):
// Let's build multiline string...
string testInput = "**\r\n" + string.Join(Environment.NewLine, Enumerable
.Range(1, 12)
.Select(i => $"{i,2}.String #{i} {(i < 3 ? "\r\n Next Line" : "")}"));
Console.WriteLine("Initial:");
Console.WriteLine();
Console.WriteLine(testInput);
Console.WriteLine();
Console.WriteLine("Parsed:");
Console.WriteLine();
// ... and parse it into lines
string[] lines = ParseList(testInput)
.Select(line => line.Trim())
.Select((item, index) => $"line number {index} = \"{item}\"")
.ToArray();
Console.WriteLine(string.Join(Environment.NewLine, lines));
结果:
Initial:
** // This text - before initial "1." marker should be ingnored
1.String #1 // 1st item contains multiline text
Next Line // 1st item continuation
2.String #2 // Again, multiline marker
Next Line
3.String #3
4.String #4
5.String #5
6.String #6
7.String #7
8.String #8
9.String #9
10.String #10 // two digit markers: "10.", "11.", "12."
11.String #11
12.String #12
Parsed:
line number 0 = "String #1 // 1st item is multiline one
Next Line"
line number 1 = "String #2 // 2nd item is multiline as well
Next Line"
line number 2 = "String #3"
line number 3 = "String #4"
line number 4 = "String #5"
line number 5 = "String #6"
line number 6 = "String #7"
line number 7 = "String #8"
line number 8 = "String #9"
line number 9 = "String #10"
line number 10 = "String #11"
line number 11 = "String #12"
编辑 2:好吧,让我们尝试另一个测试:
string testInput =
"1. test 5. wrong 2. It's Correct 3. OK 4. 1. 2. 3. - all wrong 5. Corect Now;";
string[] report = ParseList(testInput)
.Select(line => line.Trim())
.ToArray();
Console.Write(string.Join((Environment.NewLine, report));
结果:
test 5. wrong
It's Correct
OK
1. 2. 3. - all wrong
Corect Now;
关于c# - 如何将包含编号列表的字符串拆分为多个字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55849476/
我有一个数组列表: ArrayList allText = new ArrayList(); 其内容是这样的: [Alabama - Montgomery, Alaska - Juneau, Ariz
我有一个 timestamp 格式的开始和结束时间。我想将它们分成多个时间段,例如 1 小时。 $t1 = strtotime('2010-05-06 12:00:00'); $t2 = strtot
我需要将 span10 分成 3 列,但我无法将它们排列起来。我应该在 span10 中添加一个 span12 还是使用 offset 还是??
我有一个时间序列。我想从早上 8 点到第二天早上 7:59 分成 24 小时的区 block 。我知道如何按日期分组,但我尝试过使用 TimeGroupers 和 DateOffsets 处理这个 8
我收到“街道号码邮政编码城市”形式的地址(作为字符串)。我想要做的是将街道和号码与邮政编码和城市分开。通常你可以按空格分割。但有些街道名称中也有空格,例如:“Emile Van Ermengemlaa
我有一个用户列表。其中一些用户处于第一状态,而其他用户处于第二状态。所以我想要的是将这个列表显示为首先,它按排序顺序显示存在 = 1 的用户,然后按排序顺序显示存在 = 2 的用户。这里的排序是根据用
我感觉我搜索了整个网络,但找不到一种方法将不同高度的 div 很好地划分为 3 列,就像 http://www.ing.nl 上那样 headertekst headerteksttesth
Bootstrap 3 按钮下拉菜单出现问题。你可以在这里看到我的两个例子: http://www.bootply.com/W1dLusilMk http://www.bootply.com/GGBv
我在 php 中执行以下操作 foreach($QuestionAsekd as $k => $v){ $grp_name = $v['NAME']; $groupValues[$gr
我找到了一种用pandas解析html的绝妙方法。我的数据格式有点奇怪(见下文)。我想将这些数据拆分为 2 个单独的数据帧。 注意每个单元格如何由,分隔...是否有任何真正有效的方法来分割所有这些单元
HTML 看起来像这样,但我不允许对其进行更改。我只能编写 CSS 将其变成 2 列。 Povezave www.behance.net www.kiberpipa.org www.o
假设我有以下数据框“A” utilization utilization_billable service 1
我需要将 2 个文本框拉伸(stretch)到 100% 的浏览器宽度,以及一个提交按钮。所有三个都应该在一行中,我试图拉伸(stretch)它但它没有发生......有什么想法吗? 代码: .sea
我是一名优秀的程序员,十分优秀!