我得到了一些数据:
def data = "# some useless text\n"+
"# even more\n"+
"finally interesting text"
我怎样才能得到其中的“有趣的部分”?所以基本上所有的行,不以#开头。
一个 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' ]
data.eachLine {
if (!it.startsWith( '#' )
println it
}
使用split 方法获取子字符串,然后检查每个子字符串是否以“#”开头。例如:
String[] splitData = data.split("\n");
for (String eachSplit : splitData) {
if (!eachSplit.startWith("#")) {
print(eachSplit);
}
}
现在你可以测试每个字符串是否以 # 开头String.startsWith("#") .
这是使用 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"]
我会根据换行符 (\n) 拆分字符串,然后忽略以“#”开头的行。
String[] lines = data.split("\n");
for (String line : lines) {
if (line.startsWith("#") {
continue;
}
//Do stuff with the important part
}
请注意,这是纯 Java。
不需要将输入字符串转换为列表的基于正则表达式的解决方案是:
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