Sorting Arrays in Bash
Sorting an array is a very common task in any programming language. In Bash scripting, we can also accomplish this task in two different ways.
The first one uses any sorting algorithm and the second one uses a built-in keyword in Bash script called readarray. This article will show how we can sort an array in Bash script.
Furthermore, we will see some examples with explanations to make the topic easier to understand.
Sort an array using bubble sort in Bash
In Bash scripting, you can sort an array using any sorting algorithm like bubble sort, merge sort, etc. In our example below, we have implemented bubble sort to sort the array.
The code for our example is shown below.
MyArray=(9 8 20 10 15)
echo "The original array is:"
echo ${MyArray[*]}
# We implemented the bubble sort here.
for ((i = 0; i<5; i++))
do
for((j = 0; j<5-i-1; j++))
do
if [ ${MyArray[j]} -gt ${MyArray[$((j+1))]} ]
then
# swap
temp=${MyArray[j]}
MyArray[$j]=${MyArray[$((j+1))]}
MyArray[$((j+1))]=$temp
fi
done
done
echo "The sorted array is:"
echo ${MyArray[*]}
Let's explain the above example line by line.
- First, we declared an array called MyArray.
-
After that, we
echo ${MyArray[*]}
display the array via rows. - After that, we created two loops and implemented bubble sort. In these loops, we created a condition to check whether the current element is greater than the next element.
- If the condition is true, then we perform a swap operation between those two elements of the array.
- Finally, we just display the array after the sorting is done. When you run the above program, you will get the output as shown below.
The original array is:
9 8 20 10 15
The sorted array is:
8 9 10 15 20
Sorting an array using readarray keyword in Bash
Suppose you have an array that contains a mixture of alphabetical and numeric characters. To sort this array, you need to find different ways to do it.
To sort the array, you need to compare the ASCII values of the characters.
There is a built-in keyword in Bash scripting that allows you to do this in just one line of code. The keyword is readarray.
In the following example, we have created an array of combined alphabetical and numeric characters. After we sort the array using the readarray keyword, we display the sorted array.
The code for our example is shown below.
MyArray=(n a c b 6 7 5)
readarray -t MyArray < <(printf '%s\n' "${MyArray[@]}" | sort)
echo "The sorted list is: ${MyArray[*]}"
After executing the script, you will get the output as shown below.
The sorted list is: 5 6 7 a b c n
请注意
, all the codes used in this article are written in Bash. It will only work in Linux Shell environment.
For reprinting, please send an email to 1244347461@qq.com for approval. After obtaining the author's consent, kindly include the source as a link.
Related Articles
How to decompress x.tar.xz format files under Linux
Publish Date:2025/04/08 Views:186 Category:OPERATING SYSTEM
-
A lot of software found today is in the tar.xz format, which is a lossless data compression file format that uses the LZMA compression algorithm. Like gzip and bzip2, it supports multiple file compression, but the convention is not to compr
Summary of vim common commands
Publish Date:2025/04/08 Views:115 Category:OPERATING SYSTEM
-
In Linux, the best editor should be vim. However, the complex commands behind vim's powerful functions also make us daunted. Of course, these commands do not need to be memorized by rote. As long as you practice using vim more, you can reme
Detailed explanation of command return value $? in Linux
Publish Date:2025/04/08 Views:58 Category:OPERATING SYSTEM
-
? is a special variable. This variable represents the return value of the previous command. That is to say, when we run certain commands, these commands will return a code after running. Generally, if the command is successfully run, the re
Common judgment formulas for Linux script shell
Publish Date:2025/04/08 Views:159 Category:OPERATING SYSTEM
-
In shell script programming, predicates are often used. There are two ways to use predicates, one is to use test, and the other is to use []. Let's take a look at how to use these two methods through two simple examples. Example 1 # test –
Shell script programming practice - specify a directory to delete files
Publish Date:2025/04/08 Views:98 Category:OPERATING SYSTEM
-
Usually, in Linux system we need to frequently delete some temporary files or junk files. If we delete them one by one manually, it will be quite troublesome. I have also been learning shell script programming recently, so I tried to write
Use of Linux command at - set time to execute command only once
Publish Date:2025/04/08 Views:158 Category:OPERATING SYSTEM
-
This article mainly involves a knowledge point, which is the atd service. Similar to this service is the crond service. The functions of these two services can be similar to the two functional functions of javascript. Those who have learned
Use of Linux command crontab - loop execution of set commands
Publish Date:2025/04/08 Views:170 Category:OPERATING SYSTEM
-
Compared with at , which executes a command only once, crontab, which we are going to talk about in this article, executes the set commands in a loop. Similarly, the use of crontab requires the support of the crond service. The service is s
Linux practice - regularly delete files under the directory
Publish Date:2025/04/08 Views:198 Category:OPERATING SYSTEM
-
Since we want to delete the files under the directory regularly, we need to use the Linux crontab command. And the content format of each work routine is also introduced in the format of each crontab work. Similarly, we need to use shell sc
How to use the Linux file remote copy command scp
Publish Date:2025/04/08 Views:151 Category:OPERATING SYSTEM
-
Scp copies files between two hosts over the network, and the data is encrypted during transmission. Its underlying layer uses ssh for data transmission. And it has the same authentication mechanism and the same security level as ssh. When u