7

私はいくつかのデータを得ました:

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

その「面白い部分」をどう捉えるか。したがって、基本的にすべての行で、# で始まるものではありません。

4

7 に答える 7

13

Groovy の 1 つのオプションは次のとおりです。

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

分割関数を介して \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

入力文字列をリストに変換する必要のない正規表現ベースのソリューションは次のとおりです。

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 に答える
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 に答える