Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8

5

The Awk command series is getting exciting I believe, in the previous seven parts, we walked through some fundamentals of Awk that you need to master to enable you perform some basic text or string filtering in Linux.

Starting with this part, we shall dive into advance areas of Awk to handle more complex text or string filtering operations. Therefore, we are going to cover Awk features such as variables, numeric expressions and assignment operators.

Learn Awk Variables, Numeric Expressions and Assignment Operators

These concepts are not comprehensively distinct from the ones you may have probably encountered in many programming languages before such shell, C, Python plus many others, so there is no need to worry much about this topic, we are simply revising the common ideas of using these mentioned features.

This will probably be one of the easiest Awk command sections to understand, so sit back and lets get going.

1. Awk Variables

In any programming language, a variable is a place holder which stores a value, when you create a variable in a program file, as the file is executed, some space is created in memory that will store the value you specify for the variable.

You can define Awk variables in the same way you define shell variables as follows:

variable_name=value 

In the syntax above:

  1. variable_name: is the name you give a variable
  2. value: the value stored in the variable

Let’s look at some examples below:

computer_name=”tecmint.com”
port_no=”22”
email=”[email protected]”
server=”computer_name”

Take a look at the simple examples above, in the first variable definition, the value tecmint.com is assigned to the variable computer_name.

Furthermore, the value 22 is assigned to the variable port_no, it is also possible to assign the value of one variable to another variable as in the last example where we assigned the value of computer_name to the variable server.

If you can recall, right from part 2 of this Awk series were we covered field editing, we talked about how Awk divides input lines into fields and uses standard field access operator, $ to read the different fields that have been parsed. We can also use variables to store the values of fields as follows.

first_name=$2
second_name=$3

In the examples above, the value of first_name is set to second field and second_name is set to the third field.

As an illustration, consider a file named names.txt which contains a list of an application’s users indicating their first and last names plus gender. Using the cat command, we can view the contents of the file as follows:

$ cat names.txt
List File Content Using cat Command Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932636 833 Learn How to Use Awk Variables Numeric Expressions and Assignment
List File Content Using cat Command

Then, we can also use the variables first_name and second_name to store the first and second names of the first user on the list as by running the Awk command below:

$ awk '/Aaron/{ first_name=$2 ; second_name=$3 ; print first_name, second_name ; }' names.txt
Store Variables Using Awk Command Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932636 173 Learn How to Use Awk Variables Numeric Expressions and Assignment
Store Variables Using Awk Command

Let us also take a look at another case, when you issue the command uname -a on your terminal, it prints out all your system information.

The second field contains your hostname, therefore we can store the hostname in a variable called hostname and print it using Awk as follows:

$ uname -a
$ uname -a | awk '{hostname=$2 ; print hostname ; }' 
Store Command Output to Variable Using Awk Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932636 843 Learn How to Use Awk Variables Numeric Expressions and Assignment
Store Command Output to Variable Using Awk

2. Numeric Expressions

In Awk, numeric expressions are built using the following numeric operators:

  1. * : multiplication operator
  2. + : addition operator
  3. / : division operator
  4. - : subtraction operator
  5. % : modulus operator
  6. ^ : exponentiation operator

The syntax for a numeric expressions is:

$ operand1 operator operand2

In the form above, operand1 and operand2 can be numbers or variable names, and operator is any of the operators above.

Below are some examples to demonstrate how to build numeric expressions:

counter=0
num1=5
num2=10
num3=num2-num1
counter=counter+1

To understand the use of numeric expressions in Awk, we shall consider the following example below, with the file domains.txt which contains all domains owned by Tecmint.

news.tecmint.com
tecmint.com
linuxsay.com
windows.tecmint.com
tecmint.com
news.tecmint.com
tecmint.com
linuxsay.com
tecmint.com
news.tecmint.com
tecmint.com
linuxsay.com
windows.tecmint.com
tecmint.com

To view the contents of the file, use the command below:

$ cat domains.txt
View Contents of File Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932553 606 Learn How to Use Awk Special Patterns    BEGIN and END
View Contents of File

If we want to count the number of times the domain tecmint.com appears in the file, we can write a simple script to do that as follows:

#!/bin/bash
for file in [email protected]; do
        if [ -f $file ] ; then
                #print out filename
                echo "File is: $file"
                #print a number incrementally for every line containing tecmint.com 
                awk  '/^tecmint.com/ { counter=counter+1 ; printf "%sn", counter ; }'   $file
        else
                #print error info incase input is not a file
                echo "$file is not a file, please specify a file." >&2 && exit 1
        fi
done
#terminate script with exit code 0 in case of successful execution 
exit 0
Shell Script to Count a String or Text in File Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932636 830 Learn How to Use Awk Variables Numeric Expressions and Assignment
Shell Script to Count a String or Text in File

After creating the script, save it and make it executable, when we run it with the file, domains.txt as out input, we get the following output:

$ ./script.sh  ~/domains.txt
Script to Count String or Text Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932636 883 Learn How to Use Awk Variables Numeric Expressions and Assignment
Script to Count String or Text

From the output of the script, there are 6 lines in the file domains.txt which contain tecmint.com, to confirm that you can manually count them.

3. Assignment Operators

The last Awk feature we shall cover is assignment operators, there are several assignment operators in Awk and these include the following:

  1. *= : multiplication assignment operator
  2. += : addition assignment operator
  3. /= : division assignment operator
  4. -= : subtraction assignment operator
  5. %= : modulus assignment operator
  6. ^= : exponentiation assignment operator

The simplest syntax of an assignment operation in Awk is as follows:

$ variable_name=variable_name operator operand

Examples:

counter=0
counter=counter+1

num=20
num=num-1

You can use the assignment operators above to shorten assignment operations in Awk, consider the previous examples, we could perform the assignment in the following form:

variable_name operator=operand
counter=0
counter+=1

num=20
num-=1

Therefore, we can alter the Awk command in the shell script we just wrote above using += assignment operator as follows:

#!/bin/bash
for file in [email protected]; do
        if [ -f $file ] ; then
                #print out filename
                echo "File is: $file"
                #print a number incrementally for every line containing tecmint.com 
                awk  '/^tecmint.com/ { counter+=1 ; printf  "%sn",  counter ; }'   $file
        else
                #print error info incase input is not a file
                echo "$file is not a file, please specify a file." >&2 && exit 1
        fi
done
#terminate script with exit code 0 in case of successful execution 
exit 0
Alter Shell Script Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 Learn How to Use Awk Variables, Numeric Expressions and Assignment Operators – Part 8 1605932636 654 Learn How to Use Awk Variables Numeric Expressions and Assignment
Alter Shell Script

In this segment of the Awk series, we covered some powerful Awk features, that is variables, building numeric expressions and using assignment operators, plus some few illustrations of how we can actually use them.

These concepts are not any different from the one in other programming languages but there may be some significant distinctions under Awk programming.

In part 9, we shall look at more Awk features that is special patterns: BEGIN and END. Until then, stay connected to Tecmint.

This website uses cookies to improve your experience. We'll assume you're ok with this, but you can opt-out if you wish. Accept Read More