grep -r
exists and is even more faster and doesn't require passing around file names.
grep -r --include='*.txt' 'somename' .
From Wikipedia, the free encyclopedia
Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).
Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.
Community icon by Alpár-Etele Méder, licensed under CC BY 3.0
grep -r
exists and is even more faster and doesn't require passing around file names.
grep -r --include='*.txt' 'somename' .
Or use strings
if you want clean binary results. (Grep can probably do this, too)
Edit: Yes, with -b
, also -R
follows symlinks unlike -r
This does not need to be a 8 minute video. Read your tldw instead. Thanks, OP.
Better than the video thank you, I didn't watch the video
Then you dont know how the video is :D
Not the person above, but I know that written explanations of command line tools are always preferred by myself.
No, no, you just need to seek through the time and copy & paste the text in the video!
Why didn't I think of that? This is a game changer!
I know it's 8 minutes long.
Skip to 2:46 how she also mentioned in the description
Just for the sake of completeness:
https://github.com/BurntSushi/ripgrep
https://github.com/ggreer/the_silver_searcher
It's useful to be able to do this without additional tools (and there are more applications for the general command setup discussed in the video), but in practice, ease of use and performance often make a difference.
I have rg installed but only used it for basic grep replacement
I kinda prefer xargs
to the -exec
option
just feels more UNIXy to me (do one one job well).
But as another comment said, for grep
I just use -r
and --include
. So clearly I'm not very consistent...
Her presentations are fun. Thanks! Great watch.
I prefer to watch videos via peertube, not youtube, whenever possible. She has a peertube channel so here is the same video there: https://tinkerbetter.tube/w/g8K2zBgwwwE1xukkT6EmSo
It is important to have backups for when Youtube blocks clients, but I just watch it over a VPN and Freetube or Grayjay. Not leeching any resources when avoidable, just costing big brother money.
You're giving all your data to your VPN company, though
True. But I pay them via Monero
And give no personal information? Like Mullvad? That is an improvement.
Yup. Also their VPN app on Linux is better than what KDE and GNOME have. Poorly. They hook into it very intensely, early boot blocking via a systemd service and all.
She’s done such a good job with this channel. I understand most of the content, but I always pick up a nugget of new as well as being able to better explain after a topic she ELI5’d
If you have a very large directory, find will check each individual file, even when -path
doesn't match, which makes it take longer to complete. Combine -o
and -prune
to omit them entirely.
find . -path '**/node_modules/**' -prune -o -type f -name '*.js' -exec grep 'import' {} +
When using both {}
and ;
, it’s safer to use single quotes to escape the current argument and ending delimiter; eg ’{}’
and ’;’
, respectively.
Why? The quotes will be consumed by the shell when you execute the command, unless you do like "'{}'"
Thank you for the TL;dw. Sincerely appreciated.