スプリッター : の前の行にある重複したユーザー名を削除し、これらのユーザー名の最初の行のみを保持します。
行の例:
zzzz:000000zl
zzzz:000000zl!
zzzz:000000zl1
zzzz:000000zl123
zzzz:000000zl69
zzzz:000000zl?
AdSFF12:Sample198445
AdSFF12:Sample198445!
AdSFF12:Sample198445#
AdSFF12:Sample198445$
AdSFF12:Sample1984456
TestOf13:Smpletest1211
TestOf13:Smpletest1211!
TestOf13:Smpletest1211#
TestOf13:Smpletest1211$
TestOf13:Smpletest12112
TestOf13:Smpletest561
TestOf13:Smpletest561!
TestOf13:Smpletest561#
TestOf13:Smpletest561$
TestOf13:Smpletest5612
TestOf13:SmpletestZ2
TestOf13:SmpletestZ2!
TestOf13:SmpletestZ2#
TestOf13:SmpletestZ2$
TestOf13:SmpletestZ23
TestOf13:Smpletestz3qwe
TestOf13:Smpletestz3qwe!
TestOf13:Smpletestz3qwe1
TestOf13:Smpletestz3qwe123
TestOf13:Smpletestz3qwe69
TestOf13:Smpletestz3qwe?
必要な結果:
zzzz:000000zl
AdSFF12:Sample198445
TestOf13:Smpletest1211
あなたの助けは非常にありがたいです、よろしくお願いします<3。
答え1
- Ctrl+H
- 検索対象:
^((.*?:).+\R)(\2.+\R)+
- と置換する:
$1
- チェック 包み込む
- チェック 正規表現
- チェックを外す
. matches newline
- Replace all
説明:
^ # beginning of line
( # start group 1
( # start group 2
.*? # 0 or more any character but newline, not greedy
: # a colon
) # end group 2
.+ # 0 or more any character but newline
\R # any kind of linebreak (i.e. \r, \n, \r\n)
) # end group 1
( # group 3, you can use (?: for non capture group
\2 # back reference to group 2 (i.e. the part before the colon)
.+ # 0 or more any character but newline
\R # any kind of linebreak (i.e. \r, \n, \r\n)
)+ # end of group 3, may appear 0 or more times
交換:
$1 # content of group 1, the value of the first line
スクリーンショット(前):
スクリーンショット(後):