commandlinefu.com is the place to record those command-line gems that you return to again and again.
Delete that bloated snippets file you've been using and share your personal repository with the world. That way others can gain from your CLI wisdom and you from theirs too. All commands can be commented on, discussed and voted up or down.
If you have a new feature suggestion or find a bug, please get in touch via http://commandlinefu.uservoice.com/
You can sign-in using OpenID credentials, or register a traditional username and password.
First-time OpenID users will be automatically assigned a username which can be changed after signing in.
Every new command is wrapped in a tweet and posted to Twitter. Following the stream is a great way of staying abreast of the latest commands. For the more discerning, there are Twitter accounts for commands that get a minimum of 3 and 10 votes - that way only the great commands get tweeted.
» http://twitter.com/commandlinefu
» http://twitter.com/commandlinefu3
» http://twitter.com/commandlinefu10
Use your favourite RSS aggregator to stay in touch with the latest commands. There are feeds mirroring the 3 Twitter streams as well as for virtually every other subset (users, tags, functions,…):
Subscribe to the feed for:
making it "sound" more "natural" language like -- additionally sorting the longest words alphabetically:
this approach is using:
* to get at all lines of input
* post-"for" structure
* short-circuit-or in sort: if the lengths are the same, then sort alphabetically otherwise don't even evaluate the right hand side of the or
* -C sets all input and ouput channels to utf8
There is 1 alternative - vote for the best!
This command displays a list of lines that are longer than 72 characters. I use this command to identify those lines in my scripts and cut them short the way I like it.
If you can do better, submit your command here.
You must be signed in to comment.
perl -ne 'printf("%d\t%s", length, $_)'< /usr/share/dict/words | sort -n | tail | cut -f2
this is not better just showing that schwartzian transform can be applied in perl one-liner..
perl -C -e 'print map { $_->[0] } sort { $a->[1] <=> $b->[1] } map { [$_,length $_] } <>' < /usr/share/dict/words | tailthe first approach was to show a more 'idiomatic' version to syssyphus' approach.
the cool thing with schwartzian transforms is, you can plug more parts in, e.g. this equivalent (not efficient!):
perl -C -e 'print map { $_->[0] } reverse grep { $got++ < 1_0 } reverse sort { $a->[1] <=> $b->[1] } map { [$_,length $_] } <>' < /usr/share/dict/words