簡體   English   中英

使用多行迭代String

[英]Iterate through String with multiple lines

我得到了一些數據:

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' ]

使用split方法獲取子字符串然后檢查每個以“#”開頭的字符串。 例如:

String[] splitData = data.split("\n");
for (String eachSplit : splitData) {
  if (!eachSplit.startWith("#")) {
    print(eachSplit);
  }
}
data.eachLine {
    if (!it.startsWith( '#' )
        println it
}

如何通過split函數將字符串與\\ n字符分開

現在你可以測試每個字符串,如果它以#開頭或不通過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'

如果你需要將輸入拆分成行,你仍然可以使用regexp,使用Collection#grep方法:

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

PS:Regexps FTW! = P

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM