7

我得到了一些数据:

def data = "# some useless text\n"+
        "# even more\n"+
        "finally interesting text"

我怎样才能得到其中的“有趣的部分”?所以基本上所有的行,不以#开头。

4

7 回答 7

13

一个 Groovy 选项是:

def data = '''# some useless text
             |# even more
             |finally interesting text'''.stripMargin()

List lines = data.split( '\n' ).findAll { !it.startsWith( '#' ) }

assert lines == [ 'finally interesting text' ]
于 2013-01-22T00:14:26.970 回答
10
data.eachLine {
    if (!it.startsWith( '#' )
        println it
}
于 2015-03-31T20:10:41.307 回答
7

使用split 方法获取子字符串,然后检查每个子字符串是否以“#”开头。例如:

String[] splitData = data.split("\n");
for (String eachSplit : splitData) {
  if (!eachSplit.startWith("#")) {
    print(eachSplit);
  }
}
于 2013-01-22T00:05:08.653 回答
1

如何通过split 函数用 \n 字符分割字符串

现在你可以测试每个字符串是否以 # 开头String.startsWith("#") .

于 2013-01-22T00:03:28.380 回答
1

这是使用 Groovy 的元编程功能 ( http://groovy.codehaus.org/JN3525-MetaClasses ) 的解决方案:

def data = "# some useless text\n"+
    "# even more\n"+
    "finally interesting text"

String.metaClass.collectLines = { it ->
    delegate.split('\n').findAll it
}

def result = data.collectLines{ !it.startsWith( '#' )}

assert result == ["finally interesting text"]
于 2013-01-22T18:38:17.767 回答
0

我会根据换行符 (\n) 拆分字符串,然后忽略以“#”开头的行。

String[] lines = data.split("\n");
for (String line : lines) {
    if (line.startsWith("#") {
        continue;
    }
    //Do stuff with the important part
}

请注意,这是纯 Java。

于 2013-01-22T00:03:44.487 回答
0

不需要将输入字符串转换为列表的基于正则表达式的解决方案是:

def data = '''\
# some useless text
# even more
finally interesting text'''

assert data.replaceAll(/#.*\n/, '') == 'finally interesting text'

如果您仍然需要将输入拆分为行,您仍然可以使用正则表达式,使用以下Collection#grep方法:

assert data.split('\n').grep(~/[^#].*/) == ['finally interesting text']

PS:正则表达式 FTW!=P

于 2013-01-22T00:40:17.807 回答