官术网_书友最值得收藏!

Striping/altering/sorting/deleting/searching strings with Bash only

So far, we have seen inkling of the power of commands available in Linux, and some of these are among the most powerful: sed and grep. However, while we can easily use these commands together, sed by itself or even using another very useful command called awk, we can leverage Bash itself to shave time and reduce external dependencies in a portable way!

So, how can we do this? Let's begin with a few examples using this Bash syntax:

#!/bin/bash
# Index zero of VARIABLE is the char 'M' & is 14 bytes long
VARIABLE="My test string"
# ${VARIABLE:startingPosition:optionalLength}
echo ${VARIABLE:3:4}

In the preceding example, we can see a special way of calling special substring functionality using ${...} , where VARIABLE is a string variable within your script (or even global), and then the following variable is the :. After the :, there is the startingPosition parameter (remember that strings are just arrays of characters and each character can be addressed by index), and there is another optional semicolon and length parameter (optionalLength). 

If we ran this script, the output would be:

$ bash script.sh
test

How is this possible, you may ask? Well, its possible with Bash's equivalent of substr (a function in C and many other programming languages), and this is achieved through the usr of the ${...}syntax. This tells bash to look inside for a variable named VARIABLE and then for two parameters: to start at byte/character 3 (technically 4 because arrays start at element 0 in Bash) and a length of 4 (to print only four characters). The result of the echo is test.

Can we do more with this, such as removing the last character? Deleting words? Searching? Of course, and all of this is covered in this recipe!

主站蜘蛛池模板: 苗栗县| 尚义县| 论坛| 离岛区| 阿瓦提县| 革吉县| 红桥区| 弥勒县| 汝城县| 遂平县| 黑河市| 务川| 社旗县| 遵化市| 溆浦县| 兰西县| 顺平县| 禹州市| 通化市| 乌海市| 连平县| 天等县| 德钦县| 静海县| 永宁县| 镶黄旗| 河西区| 博客| 望都县| 茶陵县| 福清市| 吉隆县| 贡觉县| 封丘县| 汤原县| 吐鲁番市| 武安市| 巴南区| 洛阳市| 抚松县| 中牟县|