Get lines of file matching a regex

The name of the pictureThe name of the pictureThe name of the pictureClash 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;










share|improve this question























  • 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; write m.../... or m#../..# instead.
    – mosvy
    Nov 30 at 9:31















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;










share|improve this question























  • 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; write m.../... or m#../..# instead.
    – mosvy
    Nov 30 at 9:31













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;










share|improve this question















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






share|improve this question















share|improve this question













share|improve this question




share|improve this question








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 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; write m.../... or m#../..# 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










  • @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; write m.../... or m#../..# 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











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.






share|improve this answer






















  • 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










Your Answer








StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "106"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















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

























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.






share|improve this answer






















  • 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














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.






share|improve this answer






















  • 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












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.






share|improve this answer














 @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.







share|improve this answer














share|improve this answer



share|improve this answer








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
















  • 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

















draft saved

draft discarded
















































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.




draft saved


draft discarded














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





















































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






Popular posts from this blog

How to check contact read email or not when send email to Individual?

How many registers does an x86_64 CPU actually have?

Nur Jahan