Guide to Unix/Commands/Miscellaneous
sync
editsync write memory buffers to disk
Example: Sync has no options, doesn't display any messages
$ sync
Tips:
It is always good to type sync a couple of times, one the important functions of sync is to update your superblock information.
The sync calls sync Unix system call and exits with success code '0' or '1' if it fails. These exit codes stored in $? variable.
$ sync $ echo $? 0
The above example shows that sync was successful.
Links:
echo
editecho outputs its parameters to the standard output.
Examples:
$ echo "hello world" hello world
Tips: Some common echo usage:
Check a shell variable:
$ echo $EDITOR emacs
Check the parameters passed in the previous command:
$ ls -l ......... $ echo $_ -l
Check the current parent process:
$ echo $0 bash
Check the exit code of the last command:
$ echo $? 0
Create a empty file (same as touch /tmp/newfile):
$ echo "" > /tmp/newfile
Create a new file with some text:
$ echo "exec fluxbox" > ~/.xinitrc
Add (append) a new line to end of file:
$ echo "A New Line" >> /tmp/newfile
Links:
- echo, opengroup.org
- echo man page, man.cat-v.org
- 15.1 echo in GNU Coreutils manual, gnu.org
printf
editProduces formatted output, richer than echo.
Examples:
- printf Hello world
- Outputs Hello world, with no final newline.
- printf "Hello "; printf "world"
- As above, with no newline to separate Hello and world.
- printf "Hello world\n"
- Outputs Hello world, with a final newline via \n.
- printf "Hello\tworld"
- Outputs Hello, then tab character, then world. Other escape sequences supported include \\, \n, \r, and more.
- printf "Hello\011world"
- As above: 011 is the octal number of the tab character.
- printf "%0x" 255
- Outputs ff, that is, 255 converted to hex.
- printf "%s %0x" Hex: 255
- Takes "Hex:" as the 1st argument to be formatted using %s and 255 to be the 2nd argument to be formatted using %0x.
- printf "%s\n" 1 2 3 4 5
- Outputs the integers 1,..., 5, one integer per line. Thus, feeds the 2nd to last argument into the format string as if in a loop.
- printf "%s-%s\n" 1 2 3 4 5 6
- Outputs lines containing 1-2, 3-4, and 5-6. Thus, repeatedly lets the format string consume as many arguments as it needs.
- printf "%s-%s-%s\n" 1 2 3 4
- Outputs lines containing 1-2-3 and 4--. Thus, the arguments missing to provide complete triplets are treated as empty.
- printf "%i-%i-%i\n" 1 2 3 4
- Outputs lines containing 1-2-3 and 4-0-0. Thus, the arguments missing to provide complete triplets are treated as zeros.
- printf "%o" 255
- Outputs 377, octal of 255.
- printf "%X" 255
- Outputs FF, hex of 255 with capital letters.
Links:
- printf, opengroup.org
- printf, freebsd.org
- 15.2 printf in GNU Coreutils manual, gnu.org
cal
editOutputs a calendar, per default for the current month. If followed by a year, outputs calendar for that year; if followed by a month and a year, outputs a calendar for that period. POSIX supports no options: all options are extensions. The options of linux-util cal, GNU gcal and FreeBSD cal are generally incompatible.
Introductory examples, covered by POSIX:
$ cal April 2004 Su Mo Tu We Th Fr Sa 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
$ cal 01 2007 January 2007 Su Mo Tu We Th Fr Sa 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
More examples for POSIX cal:
- cal 2004
- Outputs a calendar for the whole year 2004.
Examples for util-linux cal:
- cal Mar 2000
- Outputs March of year 2000.
- cal -3
- Outputs current, previous and next month.
- cal -3 04 2004
- Outputs April 2004, as well as the previous (March) and following (May) month. Works in util-linux and FreeBSD.
- cal -1
- Outputs the current month, default per POSIX.
- cal -n 2 06 2020
- Outputs the calendar for June (06) and July, thus, for 2 months starting with the month entered.
- cal -j
- Outputs this months calendar with day-of-year number (counted from January 1st) rather than the date
- cal -w
- Outputs week number in addition to the daily calendar.
Examples for GNU gcal:
- gcal
- Outputs current month.
- gcal .
- Outputs current, previous and next month.
- gcal Jan
- Outputs current January.
- gcal Jan-Mar
- Outputs current January through March.
- gcal Jan 2000
- Outputs the January of 2000.
- gcal -K
- Outputs week number in addition to the daily calendar.
Tips: The Gregorian Calendar was adopted in the British Empire in 1752. The 2nd day of September 1752 was immediately followed by the 14th day of September:
$ cal 9 1752 September 1752 Su Mo Tu We Th Fr Sa 1 2 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30
Links:
- cal, opengroup.org
- cal man page, man.cat-v.org
- cal, freebsd.org
- cal in util-linux, man7.org
- GNU gcal manual, gnu.org
- cal (command), wikipedia.org
- cal.c in util-linux, github.com
- gcal.git, git.savannah.gnu.org
- ncal.c in freebsd-src, github.com
date
editdate displays the current date and time.
Example:
$ date Mon Jun 26 12:34:56 CDT 2006
Links:
- date, opengroup.org
- date man page, man.cat-v.org
- 21.1 date in GNU Coreutils manual, gnu.org
time
edittime time a program
Example:
$ time real 0m1.818s user 0m0.770s sys 0m0.210s
Links:
- time, opengroup.org
- time man page, man.cat-v.org
from
editfrom display the names of those who sent you mail recently
Example:
$ from From andy@box.po Sat Feb 05 08:52:37 2005 From andy@box.po Sat Feb 05 08:53:52 2005
Count the number of mail in your mailbox
$ from -c There are 2 messages in your incoming mailbox.
Links:
- from, freebsd.org
- 2.3 frm and from in GNU Mailutils Manual, gnu.org
mail allows you to read and write emails.
Example:
$ mail No mail for user. $ mail user2 Subject: What's up? Hi user2, you can delete this rubbish by pressing 'd'. Cc: user
Tips: Note that you need to press enter then ctrl+d to confirm.
$ mail Mail version 8.1 6/6/93. Type ? for help. "/var/spool/mail/user": 1 message 1 new >N 1 user@unix.com Tue Jun 27 12:34 16/674 "What's up?" &
Tips: Press enter to read.
Links:
- mail man page, man.cat-v.org
- 2.4 mail in GNU Mailutils Manual, gnu.org
clear
editClears the screen of the terminal. Takes no arguments. Keywords: cls.
Links:
- clear man page, man.cat-v.org
seq
editOutputs sequences of numbers, even floating point numbers. Seems not covered by POSIX.
Examples:
- seq 10
- Outputs integers 1 to 10, one per line.
- seq 2 10
- Outputs integers 2 to 10.
- seq 3 2 10
- Outputs integers 3 to 10 with step 2, and therefore, 3, 5, 7, and 9.
- seq -5 5
- Outputs integers -5 to 5
- seq 0.5 0.1 1
- Outputs numbers 0.5 to 1 with step 0.1: 0.5, 0.6, 0.7, 0.8, and 0.9 (why not 1?). The decimal point vs. comma of the output seems to be locale specific.
- seq 1E3
- Outputs integers 1 to 1000, using the exponential notation.
Links:
- seq man page, man.cat-v.org
- 26.3 seq: Print numeric sequences in GNU Coreutils manual, gnu.org
- W:seq (Unix)
shuf
editRandomly shuffles file or input lines. Not covered by POSIX.
Examples:
- seq 10 | shuf
- Outputs numbers from 1 to 10 randomly shuffled, one item per line.
- shuf -e a b c
- Randomly shuffles the a, b and c items, outputting one item per line.
- shuf -i 1-10
- Outputs numbers from 1 to 10 randomly shuffled, one item per line.
Links:
- 7.2 shuf: Shuffling text in GNU Coreutils manual, gnu.org
- shuf, man7.org
- shuf, freebsd.org
- shuf, wikipedia.org
tee
editWrites the input stream into a file while at the same time passing it to standard output.
Examples:
- dir | tee dirout.txt | less
Links:
- tee, opengroup.org
- tee man page, man.cat-v.org
- 17.1 tee: Redirect output to multiple files or processes in GNU Coreutils manual, gnu.org
- W:tee (Unix)
sleep
editPauses for a period of time.
Examples:
- sleep 5
- Pauses for 5 seconds.
- sleep 10800
- Pauses for 3 hours: for 3 * 60 * 60 seconds.
- sleep 1m
- In GNU sleep, pauses for 1 minute.
- sleep 1h
- In GNU sleep, pauses for 1 hour.
- sleep 1d
- In GNU sleep, pauses for 1 day.
- sleep 0.5m
- In GNU sleep, pauses for half a minute.
- sleep 1m 30s
- In GNU sleep, pauses for 1 minute and 30 seconds.
Links:
- sleep, opengroup.org
- sleep man page, man.cat-v.org
- sleep, freebsd.org
- 25.1 sleep in GNU Coreutils manual, gnu.org
yes
editOutputs an indefinite stream of newline-separated strings "y", or other strings as specified. One of the uses is feeding the output into a command that requires user confirmation.
Examples:
- yes
- Outputs a stream of repeated "y" strings, separated by newline.
- yes hey
- Outputs a stream of repeated "hey" strings, separated by newline.
Links:
- yes, freebsd.org
- yes Linux man page, man7.org
- 15.3 yes in GNU Coreutils manual, gnu.org
- yes (Unix), wikipedia.org
true
editDoes nothing and finishes with zero exit code, indicating success.
Links:
- true, opengroup.org
- true man page, man.cat-v.org
- true, freebsd.org
- 16.2 true in GNU Coreutils manual, gnu.org
false
editDoes nothing and finishes with non-zero exit code (often 1), indicating failure.
Links:
- false, opengroup.org
- true man page, man.cat-v.org: covers both true and false
- false, freebsd.org
- 16.1 false in GNU Coreutils manual, gnu.org
env
editSets the environment for a command or outputs all environment variables. See also Environment Variables.
Examples:
- env
- Outputs all environment variables.
- env printf Hello
- Ensures command printf is called rather than the possible shell builtin.
Links:
printenv
editOutputs values of one or more environment variables or all variables if none are passed. Not covered by POSIX. Alternatives are #env to output all variables and "echo $HOME" to output a single variable, here HOME. See also Environment Variables.
Examples:
- printenv HOME
- printenv HOME USER
- printenv
- Outputs all variables.
Links:
- printenv, man.cat-v.org
- printenv, freebsd.org
- 19.3 printenv in GNU Coreutils manual, gnu.org
- Environment variable, wikipedia.org