[bash/en] Provide example outputs for

This commit is contained in:
Keith Miyake 2017-09-29 09:09:39 -07:00
parent e27533f7d1
commit 96f62560ba

View File

@ -30,59 +30,62 @@ Nearly all examples below can be a part of a shell script or executed directly i
# As you already figured, comments start with #. Shebang is also a comment. # As you already figured, comments start with #. Shebang is also a comment.
# Simple hello world example: # Simple hello world example:
echo Hello world! echo Hello world! # => Hello world!
# Each command starts on a new line, or after semicolon: # Each command starts on a new line, or after semicolon:
echo 'This is the first line'; echo 'This is the second line' echo 'This is the first line'; echo 'This is the second line'
# => This is the first line
# => This is the second line
# Declaring a variable looks like this: # Declaring a variable looks like this:
Variable="Some string" Variable="Some string"
# But not like this: # But not like this:
Variable = "Some string" Variable = "Some string" # => returns error "Variable: command not found"
# Bash will decide that Variable is a command it must execute and give an error # Bash will decide that Variable is a command it must execute and give an error
# because it can't be found. # because it can't be found.
# Or like this: # Or like this:
Variable= 'Some string' Variable= 'Some string' # => returns error: "Some string: command not found"
# Bash will decide that 'Some string' is a command it must execute and give an # Bash will decide that 'Some string' is a command it must execute and give an
# error because it can't be found. (In this case the 'Variable=' part is seen # error because it can't be found. (In this case the 'Variable=' part is seen
# as a variable assignment valid only for the scope of the 'Some string' # as a variable assignment valid only for the scope of the 'Some string'
# command.) # command.)
# Using the variable: # Using the variable:
echo $Variable echo $Variable # => Some string
echo "$Variable" echo "$Variable" # => Some string
echo '$Variable' echo '$Variable' # => Some string
# When you use the variable itself — assign it, export it, or else — you write # When you use the variable itself — assign it, export it, or else — you write
# its name without $. If you want to use the variable's value, you should use $. # its name without $. If you want to use the variable's value, you should use $.
# Note that ' (single quote) won't expand the variables! # Note that ' (single quote) won't expand the variables!
# Parameter expansion ${ }: # Parameter expansion ${ }:
echo ${Variable} echo ${Variable} # => Some string
# This is a simple usage of parameter expansion # This is a simple usage of parameter expansion
# Parameter Expansion gets a value from a variable. It "expands" or prints the value # Parameter Expansion gets a value from a variable. It "expands" or prints the value
# During the expansion time the value or parameter are able to be modified # During the expansion time the value or parameter are able to be modified
# Below are other modifications that add onto this expansion # Below are other modifications that add onto this expansion
# String substitution in variables # String substitution in variables
echo ${Variable/Some/A} echo ${Variable/Some/A} # => A string
# This will substitute the first occurrence of "Some" with "A" # This will substitute the first occurrence of "Some" with "A"
# Substring from a variable # Substring from a variable
Length=7 Length=7
echo ${Variable:0:Length} echo ${Variable:0:Length} # => Some st
# This will return only the first 7 characters of the value # This will return only the first 7 characters of the value
# Default value for variable # Default value for variable
echo ${Foo:-"DefaultValueIfFooIsMissingOrEmpty"} echo ${Foo:-"DefaultValueIfFooIsMissingOrEmpty"}
# => DefaultValueIfFooIsMissingOrEmpty
# This works for null (Foo=) and empty string (Foo=""); zero (Foo=0) returns 0. # This works for null (Foo=) and empty string (Foo=""); zero (Foo=0) returns 0.
# Note that it only returns default value and doesn't change variable value. # Note that it only returns default value and doesn't change variable value.
# Brace Expansion { } # Brace Expansion { }
# Used to generate arbitrary strings # Used to generate arbitrary strings
echo {1..10} echo {1..10} # => 1 2 3 4 5 6 7 8 9 10
echo {a..z} echo {a..z} # => a b c d e f g h i j k l m n o p q r s t u v w x y z
# This will output the range from the start value to the end value # This will output the range from the start value to the end value
# Builtin variables: # Builtin variables:
@ -121,6 +124,7 @@ then
else else
echo "Your name is your username" echo "Your name is your username"
fi fi
# True if the value of $Name is not equal to the current user's login username
# NOTE: if $Name is empty, bash sees the above condition as: # NOTE: if $Name is empty, bash sees the above condition as:
if [ != $USER ] if [ != $USER ]
@ -133,7 +137,11 @@ if [ "" != $USER ] ...
# There is also conditional execution # There is also conditional execution
echo "Always executed" || echo "Only executed if first command fails" echo "Always executed" || echo "Only executed if first command fails"
# => Always executed
echo "Always executed" && echo "Only executed if first command does NOT fail" echo "Always executed" && echo "Only executed if first command does NOT fail"
# => Always executed
# => Only executed if first command does NOT fail
# To use && and || with if statements, you need multiple pairs of square brackets: # To use && and || with if statements, you need multiple pairs of square brackets:
if [ "$Name" == "Steve" ] && [ "$Age" -eq 15 ] if [ "$Name" == "Steve" ] && [ "$Age" -eq 15 ]
@ -147,12 +155,12 @@ then
fi fi
# Expressions are denoted with the following format: # Expressions are denoted with the following format:
echo $(( 10 + 5 )) echo $(( 10 + 5 )) # => 15
# Unlike other programming languages, bash is a shell so it works in the context # Unlike other programming languages, bash is a shell so it works in the context
# of a current directory. You can list files and directories in the current # of a current directory. You can list files and directories in the current
# directory with the ls command: # directory with the ls command:
ls ls # Lists the files and subdirectories contained in the current directory
# These commands have options that control their execution: # These commands have options that control their execution:
ls -l # Lists every file and directory on a separate line ls -l # Lists every file and directory on a separate line
@ -169,7 +177,10 @@ cat file.txt
# We can also read the file using `cat`: # We can also read the file using `cat`:
Contents=$(cat file.txt) Contents=$(cat file.txt)
echo "START OF FILE\n$Contents\nEND OF FILE" echo "START OF FILE\n$Contents\nEND OF FILE" # "\n" prints a new line character
# => START OF FILE
# => [contents of file.txt]
# => END OF FILE
# Use `cp` to copy files or directories from one place to another. # Use `cp` to copy files or directories from one place to another.
# `cp` creates NEW versions of the sources, # `cp` creates NEW versions of the sources,
@ -203,6 +214,8 @@ pwd # still in first directory
mkdir myNewDir mkdir myNewDir
# The `-p` flag causes new intermediate directories to be created as necessary. # The `-p` flag causes new intermediate directories to be created as necessary.
mkdir -p myNewDir/with/intermediate/directories mkdir -p myNewDir/with/intermediate/directories
# if the intermediate directories didn't already exist, running the above
# command without the `-p` flag would return an error
# You can redirect command input and output (stdin, stdout, and stderr). # You can redirect command input and output (stdin, stdout, and stderr).
# Read from stdin until ^EOF$ and overwrite hello.py with the lines # Read from stdin until ^EOF$ and overwrite hello.py with the lines
@ -217,12 +230,15 @@ for line in sys.stdin:
print(line, file=sys.stdout) print(line, file=sys.stdout)
EOF EOF
# Run hello.py with various stdin, stdout, and stderr redirections: # Run the hello.py Python script with various stdin, stdout, and
python hello.py < "input.in" # stderr redirections:
python hello.py > "output.out" python hello.py < "input.in" # pass input.in as input to the script
python hello.py 2> "error.err" python hello.py > "output.out" # redirect output from the script to output.out
python hello.py > "output-and-error.log" 2>&1 python hello.py 2> "error.err" # redirect error output to error.err
python hello.py > /dev/null 2>&1 python hello.py > "output-and-error.log" 2>&1 # redirect both output and
# errors to output-and-error.log
python hello.py > /dev/null 2>&1 # redirect all output and errors to
# the black hole, /dev/null, i.e., no output
# The output error will overwrite the file if it exists, # The output error will overwrite the file if it exists,
# if you want to append instead, use ">>": # if you want to append instead, use ">>":
python hello.py >> "output.out" 2>> "error.err" python hello.py >> "output.out" 2>> "error.err"
@ -269,12 +285,19 @@ for Variable in {1..3}
do do
echo "$Variable" echo "$Variable"
done done
# => 1
# => 2
# => 3
# Or write it the "traditional for loop" way: # Or write it the "traditional for loop" way:
for ((a=1; a <= 3; a++)) for ((a=1; a <= 3; a++))
do do
echo $a echo $a
done done
# => 1
# => 2
# => 3
# They can also be used to act on files.. # They can also be used to act on files..
# This will run the command 'cat' on file1 and file2 # This will run the command 'cat' on file1 and file2
@ -296,6 +319,7 @@ do
echo "loop body here..." echo "loop body here..."
break break
done done
# => loop body here...
# You can also define functions # You can also define functions
# Definition: # Definition:
@ -306,6 +330,11 @@ function foo ()
echo "This is a function" echo "This is a function"
return 0 return 0
} }
# Call the function `foo` with two arguments, arg1 and arg2:
foo arg1 arg2
# => Arguments work just like script arguments: arg1 arg2
# => And: arg1 arg2...
# => This is a function
# or simply # or simply
bar () bar ()
@ -313,6 +342,8 @@ bar ()
echo "Another way to declare functions!" echo "Another way to declare functions!"
return 0 return 0
} }
# Call the function `bar` with no arguments:
bar # => Another way to declare functions!
# Calling your function # Calling your function
foo "My name is" $Name foo "My name is" $Name
@ -320,25 +351,35 @@ foo "My name is" $Name
# There are a lot of useful commands you should learn: # There are a lot of useful commands you should learn:
# prints last 10 lines of file.txt # prints last 10 lines of file.txt
tail -n 10 file.txt tail -n 10 file.txt
# prints first 10 lines of file.txt # prints first 10 lines of file.txt
head -n 10 file.txt head -n 10 file.txt
# sort file.txt's lines # sort file.txt's lines
sort file.txt sort file.txt
# report or omit repeated lines, with -d it reports them # report or omit repeated lines, with -d it reports them
uniq -d file.txt uniq -d file.txt
# prints only the first column before the ',' character # prints only the first column before the ',' character
cut -d ',' -f 1 file.txt cut -d ',' -f 1 file.txt
# replaces every occurrence of 'okay' with 'great' in file.txt, (regex compatible)
# replaces every occurrence of 'okay' with 'great' in file.txt
# (regex compatible)
sed -i 's/okay/great/g' file.txt sed -i 's/okay/great/g' file.txt
# print to stdout all lines of file.txt which match some regex # print to stdout all lines of file.txt which match some regex
# The example prints lines which begin with "foo" and end in "bar" # The example prints lines which begin with "foo" and end in "bar"
grep "^foo.*bar$" file.txt grep "^foo.*bar$" file.txt
# pass the option "-c" to instead print the number of lines matching the regex # pass the option "-c" to instead print the number of lines matching the regex
grep -c "^foo.*bar$" file.txt grep -c "^foo.*bar$" file.txt
# Other useful options are: # Other useful options are:
grep -r "^foo.*bar$" someDir/ # recursively `grep` grep -r "^foo.*bar$" someDir/ # recursively `grep`
grep -n "^foo.*bar$" file.txt # give line numbers grep -n "^foo.*bar$" file.txt # give line numbers
grep -rI "^foo.*bar$" someDir/ # recursively `grep`, but ignore binary files grep -rI "^foo.*bar$" someDir/ # recursively `grep`, but ignore binary files
# perform the same initial search, but filter out the lines containing "baz" # perform the same initial search, but filter out the lines containing "baz"
grep "^foo.*bar$" file.txt | grep -v "baz" grep "^foo.*bar$" file.txt | grep -v "baz"
@ -346,8 +387,9 @@ grep "^foo.*bar$" file.txt | grep -v "baz"
# and not the regex, use fgrep (or grep -F) # and not the regex, use fgrep (or grep -F)
fgrep "foobar" file.txt fgrep "foobar" file.txt
# trap command allows you to execute a command when a signal is received by your script. # The trap command allows you to execute a command whenever your script
# Here trap command will execute rm if any one of the three listed signals is received. # receives a signal. Here, trap will execute `rm` if it receives any of the
# three listed signals.
trap "rm $TEMP_FILE; exit" SIGHUP SIGINT SIGTERM trap "rm $TEMP_FILE; exit" SIGHUP SIGINT SIGTERM
# `sudo` is used to perform commands as the superuser # `sudo` is used to perform commands as the superuser