私はいくつかのデータを得ました:
def data = "# some useless text\n"+
"# even more\n"+
"finally interesting text"
その「面白い部分」をどう捉えるか。したがって、基本的にすべての行で、# で始まるものではありません。
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' ]
data.eachLine {
if (!it.startsWith( '#' )
println it
}
split メソッドを使用して部分文字列を取得し、それぞれが「#」で始まるかどうかを確認します。例えば:
String[] splitData = data.split("\n");
for (String eachSplit : splitData) {
if (!eachSplit.startWith("#")) {
print(eachSplit);
}
}
分割関数を介して \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"]
入力文字列をリストに変換する必要のない正規表現ベースのソリューションは次のとおりです。
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
改行文字 (\n) に基づいて文字列を分割し、「#」で始まる行を無視します。
String[] lines = data.split("\n");
for (String line : lines) {
if (line.startsWith("#") {
continue;
}
//Do stuff with the important part
}
これは純粋な Java であることに注意してください。