function-array--字符串截取--mktemp--install

简介:

function:函数

过程式编程;代码重用

模块化编程

结构化编程

语法一:

funcion f_name{

函数体

}

语法二:

f_name (){

函数体

}

调用:函数只有被调用才会执行:

函数的生命周期;被调用时创建,返回时终止

return命令返回自定义状态结果:

0;成功

1-255;失败

#!/bin/bash

#

function adduser {

if id $username &> /dev/null ;then

echo "$username exists."

return 1

else

useradd $username

[ $? -eq 0 ] && echo "ADD $username finished." && return 0

fi

}


for i in {1..10};do

username=myuser$i

adduser

done

函数可以接受参数:

传递参数给函数:调用函数时,在函数后面以空白分隔给定参数列表:例如“testfunc arg1 arg2.。”

在函数体重可以$1 ,$2...调用这些参数;还可以使用$@,$*,$#等特殊变量

#!/bin/bash

#

declare -i i=6

f1(){

local i=9 #函数内的局部变量

let i++

echo "Function:$i"

}

f1

echo "Main:$i"

函数递归:

函数直接或间接调用自身:

求阶乘

#!/bin/bash

#

fact() {

if [ $1 -eq 0 -o $1 -eq 1 ];then

echo 1

else

echo $[$1*$(fact $[$1-1])]

fi

}

fact $1


裴波那契数列

#!/bin/bash

#

fab(){

if [ $1 -eq 1 ]; then

echo 1

elif [ $1 -eq 2 ];then

echo 2

else

echo $[$(fab $[$1-1])+$(fab $[$1-2])]

fi

}

fab $1


bash脚本编程:

变量:存储单个元素的内存空间

数组:存储多个元素的连续的内存空间;

数组名:

索引:编号从0开始,属于数值索引:

注意:索引也可以支持使用自定义的格式,而不仅仅是数值格式。

引用数组中的元素:${array_name[index]}

声明数组:

declare -a array_name

declare -A array_name:关联数组:kv

数组元素的赋值;

 (1)一次只赋值一个元素;

ARRAY_NAME [INDEX]=VALUE

weekdays[0]="Sunday"

weekdays[4]="Thursday"

 (2)一次赋值全部元素:

ARRAY_NAME=(“VAL1”"VAL2""VAL3"...)

 (3)只赋值特定的元素:

ARRAY_NAME=([0]="VAL1" [3]="VAL2"...)

 (4)read -a ARRAY

引用数组中的元素:${array_name[in]}

  注意:省略[index]表示引用下标为0的元素;

数组的长度:${#ARRAY_NAME[*]},${#ARRAY_NAME[@]}

生成10个随机数,并找出最大值;

#!/bin/bash

#

declare -a rand

declare -i max=0


for i in {0..9};do

rand[$i]=$RANDOM

echo ${rand[$i]}

[ ${rand[$i]} -gt $max ] && max=${rand[$i]}

done

echo "Max: $max"

写一个脚本,定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件:统计其下标为偶数的文件中的行数之和;

#!/bin/bash

#

declare -a files

files=(/var/log/*.log)

declare -i lines=0


for i in $(seq 0 $[${#files[*]}-1]); do

if [ $[$i%2] -eq 0 ];then

let lines+=$(wc -l ${files[$i]} | cut -d' ' -f1 )

fi

done

echo "lines:$lines."

引用数组中的元素;

所有元素:${array_name[*]},${array_name[@]}

${ARRAY[@]:offset:number}

offset:要跳过个的元素个数

number:要取出的元素个数,取偏移量之后的所有元素 ${ARRAY[@]:offset}

向数组中追加元素;

ARRAY[${#ARRAY[*]}]

删除数组中的某个元素;

unset ARRAY[INDEX]

关联数组;

declare -A ARRAY_NAME

ARRAY_NAME=([index_name1]='val1' [index_name2]='val2'.... )

bash的字符串处理工具;

字符串切片:${var:offset:number}

name="obkjl"

echo ${name:1:3}

echo ${name:1}

echo ${name: -3} 冒号后面必须有个空格,表示从右侧开始取

基于模式取子串;

从左到右

${var#*word}:第一次匹配到word之后的部分,之前部分删除

${var##*word}:最后一次匹配到word.之前的部分删除

从右到左

${var%word*}

file="/etc/httpd/conf/httpd.conf"

echo ${file%/*}

${var%%word*}

查找替换;

${var/pattern/substi}:查找var中,第一次出现pattern所匹配的字符串,用substi替换

${var//pattern/substi}:查找var中,所有出现pattern所匹配的字符串,用substi替换

${var/#pattern/substi}:查找var中,行首出现pattern所匹配的字符串,用substi替换

${var/%pattern/substi}:查找var中,行尾出现pattern所匹配的字符串,用substi替换

查找并删除:没有写明替换内容substi,则为删除操作

${var/pattern}:查找var中,删除第一次出现pattern所匹配的字符串

${var//pattern}

${var/#pattern}

${var/%pattern}

字符大小写转换;

${var^^}把var中所有的小写转换为大写

${var,,}把var中所有的大写转换为小写

变量赋值:

${var:-value}:如果var为空或者未设置,那么返回value;否则返回var的值

${var:=value}:如果var为空或者未设置,那么返回value;并将values赋值给var,否则,则返回var的值

${var:+value}:如果var不空,则返回value;

${var:?error_info}:如果var为空或者未设置,返回err_info:否则,返回var的值;

在脚本中读取配置文件

定义文本文件,每行定义“name=value”

在脚本中source此文件即可

命令:

mktemp命令:创建临时文件

mktemp /tmp/test.xxx

tmpfile=${mktemp /tmp/test.XXX}:引用

mktemp -d /tmp/test.xxx 创建临时目录

--tmpdir

=/path/to/somedir:指明临时文件路径

install命令

install [OPTION]... [-T] SOURCE DEST

install [OPTION]... SOURCE... DIRECTORY

install [OPTION]... -t DIRECTORY SOURCE...

install [OPTION]... -d DIRECTORY...

install可以在复制的同时指定权限,属主,组等

-m mode

-o owner

-g group

     本文转自阿伦艾弗森 51CTO博客,原文链接:http://blog.51cto.com/perper/1955405,如需转载请自行联系原作者







相关文章
|
17天前
|
资源调度 Serverless 计算机视觉
高斯函数 Gaussian Function
**高斯函数,或称正态分布,以数学家高斯命名,具有钟形曲线特征。关键参数包括期望值μ(决定分布中心)和标准差σ(影响分布的宽度)。当μ=0且σ²=1时,分布为标准正态分布。高斯函数广泛应用于统计学、信号处理和图像处理,如高斯滤波器用于图像模糊。其概率密度函数为e^(-x²/2σ²),积分结果为误差函数。在编程中,高斯函数常用于创建二维权重矩阵进行图像的加权平均,实现模糊效果。
14 1
|
1月前
|
算法 Serverless C语言
CMake函数和宏(function和macro):使用函数和宏提高代码可读性
CMake函数和宏(function和macro):使用函数和宏提高代码可读性
30 1
|
1月前
|
存储 安全 编译器
【C++ 包装器类 std::function 和 函数适配器 std::bind】 C++11 全面的std::function和std::bind的入门使用教程
【C++ 包装器类 std::function 和 函数适配器 std::bind】 C++11 全面的std::function和std::bind的入门使用教程
32 0
|
1月前
|
SQL Oracle 关系型数据库
Flink的表值函数(Table-Valued Function,TVF)是一种返回值是一张表的函数
【2月更文挑战第17天】Flink的表值函数(Table-Valued Function,TVF)是一种返回值是一张表的函数
20 1
|
6月前
|
存储 数据安全/隐私保护
均匀散列函数(Uniform Hash Function)
均匀散列函数(Uniform Hash Function)是一种将不同长度的输入数据映射到相同大小的输出数据的散列函数。均匀散列函数的主要特点是,对于相同的输入数据,无论其长度如何,都会得到相同的输出散列值。这种散列函数常用于数据结构的存储和查找,例如哈希表、散列表等。
97 3
|
3月前
|
存储 SQL 安全
函数(Function)和存储过程(Stored Procedure)的区别(小白情感版)
函数(Function)和存储过程(Stored Procedure)的区别(小白情感版)
31 0
|
3月前
|
缓存
pytest 运行测试函数报错的解决办法 TypeError: calling <function xxx> returned None, not a test
pytest 运行测试函数报错的解决办法 TypeError: calling <function xxx> returned None, not a test
87 0
|
3月前
|
数据库
SAP ABAP 更新函数(Update Function Module)执行出错的原因分析试读版
SAP ABAP 更新函数(Update Function Module)执行出错的原因分析试读版
35 0
|
3月前
|
数据库
130. SAP ABAP 更新函数(Update Function Module)执行出错的原因分析
130. SAP ABAP 更新函数(Update Function Module)执行出错的原因分析
25 0
|
4月前
|
SQL
Greenplum【SQL 03】实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录)
Greenplum【SQL 03】实现树结构+自定义函数+避免函数重复调用+ function cannot execute on a QE slice 问题处理(优化过程全记录)
33 0

热门文章

最新文章