shell_Day08
数组与字符串:
数组
数组就是一段连续的变量,一段连续的内存存储空间
为了解决变量过多的问题; 在同一类变量中,我们不需要去定义多个名字,而是以数组的方式来定义;(列表)
数组名[索引]=值
定义数组
declare -i 定义整数 (申明)
declare -a 定义数组array
declare -A 定义嵌套的数组
索引并不一定是数字
shell中数组赋值,可以跳跃(跳跃赋值)
array=(/var/log/*.log)
做遍历
array=(a b c d e)
array=('a=187' 'b=186' ... )
通过read命令来赋值
read -t 延迟 -p "指定说明" -a 输入数组所需的变量值
read -a a b c d e
调用数组
${变量名}
${数组名[索引]} 定义的是哪个索引,就看到是对应索引指定的值
${数组名} 默认调用 索引=0 的值 $array(最好不要这样写)
${数组名[*]} 或者 ${数组名[@]} 调用数组内所有的值 $* $@
调用数组的数组长度
length("变量")
${#变量名[*]} 或者 ${#变量名[@]}
添加数组值的特殊方式
${变量名[${#变量名[@]}]}="值" 或者 ${变量名[${#变量名[*]}]}="值"
关于数组的其他操作
数组切片
${变量名[@]:偏移量:所需要取出值的个数}
echo ${a[*]:2:4}
${变量名[@]:偏移量}
删除值
unset ${变量名[索引]}
注意:删除是索引所对的值,而没有带着索引一块删除;
修改值
a[3]=c
a[3]=d 覆盖即修改
字符串:
python ( %s , %d ) % (name, hiaght)
输出: aa,1832
%d
%f
%[num]s 指定该字符串占位的宽度
%-[num]s 代表左对齐
字符串切片:
数组切片:${变量名[@]:偏移量:数值个数}
字符串:${变量名:偏移量:数值个数}
${变量名: -数值个数} 【*注意:冒号后面一定要加空格*】
${变量名:-word} 默认赋值的意思
read "sasasa:" test
[ -z $test ] && test=abc
基于模式取子字符串
从左自右
${变量名#pattern} 删除pattern第一次匹配到的字串
${变量名##pattern} 删除所有pattern匹配到的字串
从右自左
${变量名%pattern}
${变量名%%pattern}
字符替换
${变量名/pattern/替换后的字符串} 【pattern并不是正则表达式,而是文件通配符】
匹配第一个pattern,来进行替换
${变量名//pattern/替换后的字符串}
匹配所有哦pattern,并进行替换
${变量名/#pattern/替换后的字符串}
指定匹配行首必须是 pattern ,才会替换
${变量名/%pattern/替换后的字符串}
指定匹配行尾必须是 pattern , 才会替换
查找并删除
替换中,不指定替换字符串,即为删除
${变量名/pattern}
${变量名//pattern}
${变量名/#pattern}
${变量名/%pattern}
替换大小写
tr 替换大小写
tr [[:lower:]] [[:upper:]] < filename
${变量名,,} 将字符串全部替换为小写
变量赋值
变量名1=${变量名2:-word} 注意没有空格! 输入默认值的作用 , 变量2 没有值,就将 word 默认值赋值给 变量1
变量名1=${变量名2:+word} 不常用 变量2 有值的情况下,才将 word默认值赋值给变量1
${变量:=word} 如果变量没有值,就将word赋值给变量,有值,则使用原来的值
变量1=${变量2:?error_infor} 如果变量2 没有值,输出erro_infor错误信息
两个命令
避免取的文件名字重复;mktemp 名字.XXXXXX (XX代表随机数(字母和数字))
默认创建是随机的文件
-d 创建的就是随机的 目录
优点可以指定权限来复制文件
用法:intall a文件 b目录 //复制a文件到b目录,并回复初始权限(文件:755 目录:644)
-t 源目对换
-d 创建
-m MODE
-o OWNER
-g GROUP
虚拟化的准备知识:系统的启动原理
读取系统--读取磁盘:前提就是必须先加载磁盘的驱动程序
挂载 虚拟根(img虚根文件ramdisk)
虚根文件文件挂上以后,在grub1.5加载磁盘驱动;
通过chroot将ramdisk上面的临时“根”切换到磁盘上面
操作系统:vmlinuz的内核、ramdisk.img
shell_Day08的更多相关文章
随机推荐
- Python求取文件夹内的文件数量、子文件夹内的文件数量
本文介绍基于Python语言,统计文件夹中文件数量:若其含有子文件夹,还将对各子文件夹中的文件数量一并进行统计的方法. 最近,需要统计多个文件夹内部的文件数量,包括其中所含子文件夹中的文件数量 ...
- Zstack救急实战记录
起了这么个标题很容易引起歧义,先说明:是Zstack云架构帮我救急,而不是Zstack系统出了问题被救.具体容我慢慢道来: 使用Docker搭建EPICS的IOC记录 去年暑假时在一台工控机上裸装ce ...
- 体验AI乐趣:基于AI Gallery的二分类猫狗图片分类小数据集自动学习
摘要:直接使用AI Gallery里面现有的数据集进行自动学习训练,很简单和方便,节约时间,不用自己去训练了,AI Gallery 里面有很多类似的有趣数据集,也非常好玩,大家一起试试吧. 本文分享自 ...
- C语言小程序-天天酷跑类游戏 26号完成
1.创建游戏内背景 2.实现人物 奔跑 跳跃 优化帧 3.障碍物 出现 https://kxd.lanzoul.com/iKXU20elmtah 开源地址 半成品
- 【python自动化测试】1- python基础和pycharm使用
python基础和pycharm使用 1.pycharm 1.1 为特定格式文件添加头信息 File--Settings--Editor--File and Code Templates--Pytho ...
- k8s(docker-desktop)简单搭建zookeeper三节点集群
前提 已经安装了docker-desktop,并且其中的kubernetes启动运行的.或者安装了k8s环境就行 可以正常下载dockerhub的镜像,这里采用了dockerhub官方制作的镜像 启动 ...
- ModuleNotFoundError:No module named 'past' 问题及解决方法
训练YOLOX时报错 ModuleNotFoundError:No module named 'past' 解决方法 使用pip安装对应的package:future pip install futu ...
- BOOK01:《过目不忘的读书法》
BOOK01:<过目不忘的读书法> 01 区分"信息"和"知识" 一年之后过时的是"信息",十年也不过时的是"知识&q ...
- mysql存储过程游标中途自动退出
1.当在游标循环过程中select的结果集如果为空,就会触发游标continue handler for not found 提前将done置为1,导致提前退出游标. 2.游标循环中出现 select ...
- sparksql的join有哪些及实现原理
sparksql的3种join实现 1.Broadcast Join (小表对大表) 在数据库的常见模型中(比如星型模型或者雪花模型),表一般分为两种:事实表和维度表. 维度表一般指固定的.变动较少的 ...