Get lines of file matching a regex
Clash Royale CLAN TAG#URR8PPP
up vote
0
down vote
favorite
Is there a more compact way to get lines of a file that match a regex than the following?
open my $fh, '<', $file or die "Cannot open $file: $!";
while ( my $line = <$fh> )
next unless $line =~ m/^foo/([^/]+/?)*==/;
chomp($line);
$line =~ s/==$//g;
$search_result_set$line = 1;
files regular-expression perl
|
show 13 more comments
up vote
0
down vote
favorite
Is there a more compact way to get lines of a file that match a regex than the following?
open my $fh, '<', $file or die "Cannot open $file: $!";
while ( my $line = <$fh> )
next unless $line =~ m/^foo/([^/]+/?)*==/;
chomp($line);
$line =~ s/==$//g;
$search_result_set$line = 1;
files regular-expression perl
Can you please explain what you want to accomplish? Do not expect we will put effort to understand your script.
– Romeo Ninov
Nov 30 at 8:59
@RomeoNinov: How is the regex relevant? I was under the impression that it can be more compact in the read line by line part after opening the file
– Jim
Nov 30 at 9:08
@Inian: Same comment as above
– Jim
Nov 30 at 9:08
@RomeoNinov: E.g. I think there is something likeslurp
but that is considered insecure or something?
– Jim
Nov 30 at 9:09
1
s^(foo/[^/]+/?)==s*$$1 && $sr$_++ while <$fh>
; in any case, do not write/../../../
in perl, ever; writem.../...
orm#../..#
instead.
– mosvy
Nov 30 at 9:31
|
show 13 more comments
up vote
0
down vote
favorite
up vote
0
down vote
favorite
Is there a more compact way to get lines of a file that match a regex than the following?
open my $fh, '<', $file or die "Cannot open $file: $!";
while ( my $line = <$fh> )
next unless $line =~ m/^foo/([^/]+/?)*==/;
chomp($line);
$line =~ s/==$//g;
$search_result_set$line = 1;
files regular-expression perl
Is there a more compact way to get lines of a file that match a regex than the following?
open my $fh, '<', $file or die "Cannot open $file: $!";
while ( my $line = <$fh> )
next unless $line =~ m/^foo/([^/]+/?)*==/;
chomp($line);
$line =~ s/==$//g;
$search_result_set$line = 1;
files regular-expression perl
files regular-expression perl
edited Nov 30 at 9:21
asked Nov 30 at 8:55
Jim
390213
390213
Can you please explain what you want to accomplish? Do not expect we will put effort to understand your script.
– Romeo Ninov
Nov 30 at 8:59
@RomeoNinov: How is the regex relevant? I was under the impression that it can be more compact in the read line by line part after opening the file
– Jim
Nov 30 at 9:08
@Inian: Same comment as above
– Jim
Nov 30 at 9:08
@RomeoNinov: E.g. I think there is something likeslurp
but that is considered insecure or something?
– Jim
Nov 30 at 9:09
1
s^(foo/[^/]+/?)==s*$$1 && $sr$_++ while <$fh>
; in any case, do not write/../../../
in perl, ever; writem.../...
orm#../..#
instead.
– mosvy
Nov 30 at 9:31
|
show 13 more comments
Can you please explain what you want to accomplish? Do not expect we will put effort to understand your script.
– Romeo Ninov
Nov 30 at 8:59
@RomeoNinov: How is the regex relevant? I was under the impression that it can be more compact in the read line by line part after opening the file
– Jim
Nov 30 at 9:08
@Inian: Same comment as above
– Jim
Nov 30 at 9:08
@RomeoNinov: E.g. I think there is something likeslurp
but that is considered insecure or something?
– Jim
Nov 30 at 9:09
1
s^(foo/[^/]+/?)==s*$$1 && $sr$_++ while <$fh>
; in any case, do not write/../../../
in perl, ever; writem.../...
orm#../..#
instead.
– mosvy
Nov 30 at 9:31
Can you please explain what you want to accomplish? Do not expect we will put effort to understand your script.
– Romeo Ninov
Nov 30 at 8:59
Can you please explain what you want to accomplish? Do not expect we will put effort to understand your script.
– Romeo Ninov
Nov 30 at 8:59
@RomeoNinov: How is the regex relevant? I was under the impression that it can be more compact in the read line by line part after opening the file
– Jim
Nov 30 at 9:08
@RomeoNinov: How is the regex relevant? I was under the impression that it can be more compact in the read line by line part after opening the file
– Jim
Nov 30 at 9:08
@Inian: Same comment as above
– Jim
Nov 30 at 9:08
@Inian: Same comment as above
– Jim
Nov 30 at 9:08
@RomeoNinov: E.g. I think there is something like
slurp
but that is considered insecure or something?– Jim
Nov 30 at 9:09
@RomeoNinov: E.g. I think there is something like
slurp
but that is considered insecure or something?– Jim
Nov 30 at 9:09
1
1
s^(foo/[^/]+/?)==s*$$1 && $sr$_++ while <$fh>
; in any case, do not write /../../../
in perl, ever; write m.../...
or m#../..#
instead.– mosvy
Nov 30 at 9:31
s^(foo/[^/]+/?)==s*$$1 && $sr$_++ while <$fh>
; in any case, do not write /../../../
in perl, ever; write m.../...
or m#../..#
instead.– mosvy
Nov 30 at 9:31
|
show 13 more comments
1 Answer
1
active
oldest
votes
up vote
1
down vote
@lines = grep s^foo/([^/]+/?)*K==n?z, <$fh>;
Would store in the @lines
array the lines that match the pattern with a trailing ==n
removed. $
matches both at the end of the subject and before a trailing n
in the subject, here we're using n?z
(an optional n
followed by the end of the subject (z
)) for that newline to be removed if present, effectively doing chomp
's job. K
marks the start of the portion to be substituted.
So what about the removal part of the second regex? Should I go over the@lines
a second time?
– Jim
Nov 30 at 9:19
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
add a comment |
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
1
down vote
@lines = grep s^foo/([^/]+/?)*K==n?z, <$fh>;
Would store in the @lines
array the lines that match the pattern with a trailing ==n
removed. $
matches both at the end of the subject and before a trailing n
in the subject, here we're using n?z
(an optional n
followed by the end of the subject (z
)) for that newline to be removed if present, effectively doing chomp
's job. K
marks the start of the portion to be substituted.
So what about the removal part of the second regex? Should I go over the@lines
a second time?
– Jim
Nov 30 at 9:19
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
add a comment |
up vote
1
down vote
@lines = grep s^foo/([^/]+/?)*K==n?z, <$fh>;
Would store in the @lines
array the lines that match the pattern with a trailing ==n
removed. $
matches both at the end of the subject and before a trailing n
in the subject, here we're using n?z
(an optional n
followed by the end of the subject (z
)) for that newline to be removed if present, effectively doing chomp
's job. K
marks the start of the portion to be substituted.
So what about the removal part of the second regex? Should I go over the@lines
a second time?
– Jim
Nov 30 at 9:19
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
add a comment |
up vote
1
down vote
up vote
1
down vote
@lines = grep s^foo/([^/]+/?)*K==n?z, <$fh>;
Would store in the @lines
array the lines that match the pattern with a trailing ==n
removed. $
matches both at the end of the subject and before a trailing n
in the subject, here we're using n?z
(an optional n
followed by the end of the subject (z
)) for that newline to be removed if present, effectively doing chomp
's job. K
marks the start of the portion to be substituted.
@lines = grep s^foo/([^/]+/?)*K==n?z, <$fh>;
Would store in the @lines
array the lines that match the pattern with a trailing ==n
removed. $
matches both at the end of the subject and before a trailing n
in the subject, here we're using n?z
(an optional n
followed by the end of the subject (z
)) for that newline to be removed if present, effectively doing chomp
's job. K
marks the start of the portion to be substituted.
edited Nov 30 at 10:19
answered Nov 30 at 9:02
Stéphane Chazelas
296k54559904
296k54559904
So what about the removal part of the second regex? Should I go over the@lines
a second time?
– Jim
Nov 30 at 9:19
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
add a comment |
So what about the removal part of the second regex? Should I go over the@lines
a second time?
– Jim
Nov 30 at 9:19
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
So what about the removal part of the second regex? Should I go over the
@lines
a second time?– Jim
Nov 30 at 9:19
So what about the removal part of the second regex? Should I go over the
@lines
a second time?– Jim
Nov 30 at 9:19
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
@Jim, I missed that part of the requirement. Then, it's even simpler. See edit.
– Stéphane Chazelas
Nov 30 at 10:14
add a comment |
Thanks for contributing an answer to Unix & Linux Stack Exchange!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f485096%2fget-lines-of-file-matching-a-regex%23new-answer', 'question_page');
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function ()
StackExchange.helpers.onClickDraftSave('#login-link');
);
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Can you please explain what you want to accomplish? Do not expect we will put effort to understand your script.
– Romeo Ninov
Nov 30 at 8:59
@RomeoNinov: How is the regex relevant? I was under the impression that it can be more compact in the read line by line part after opening the file
– Jim
Nov 30 at 9:08
@Inian: Same comment as above
– Jim
Nov 30 at 9:08
@RomeoNinov: E.g. I think there is something like
slurp
but that is considered insecure or something?– Jim
Nov 30 at 9:09
1
s^(foo/[^/]+/?)==s*$$1 && $sr$_++ while <$fh>
; in any case, do not write/../../../
in perl, ever; writem.../...
orm#../..#
instead.– mosvy
Nov 30 at 9:31