Shell脚本编程

文章目录

  • 一、简介
  • 二、变量
    • 变量命名
    • 使用变量
    • 只读变量
    • 删除变量
    • 变量种类
  • 三、数组
  • 四、算数运算
  • 五、条件测试
    • 数值测试
    • 字符串测试
    • 文件测试
    • 组合测试
  • 六、选择执行
  • 七、用户交互
    • read命令
  • 八、循环语句
    • for循环
    • while循环
    • until循环
  • 九、函数
  • 十、调试脚本
  • 十一、环境配置
    • bash配置文件
    • 案例,开机显示系统信息脚本
    • 案例,监控httpd进程
    • 案例,统计两个目录

一、简介

  • Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁。Shell 既是一种命令语言,又是一
    种程序设计语言。

  • Shell 是指一种应用程序,这个应用程序提供了一个界面,用户通过这个界面访问操作系统内核的服务。(翻译官,帮你翻译命令给内核执行)
    在这里插入图片描述

  • Linux 的 Shell 种类众多,常见的有:

    • Bourne Shell(/usr/bin/sh或/bin/sh
    • Bourne Again Shell(/bin/bash)
    • C Shell(/usr/bin/csh)
    • K Shell(/usr/bin/ksh)
    • Shell for Root(/sbin/sh)
  • 程序编程风格

    • 过程式:以指令为中心,数据服务于命令
    • 对象式:以数据为中心,命令服务于数据
    • shell是一种过程式编程
  • 过程式编程

    • 顺序执行
    • 循环执行
    • 选择执行
  • 编程语言分类

    • 编译型语言
    • 解释型语言(shell是一种解释型语言)
      在这里插入图片描述
  • 运行脚本

    • 给予执行权限,通过具体的文件路径指定文件执行
    • 直接运行解释器,将脚本作为解释器程序的参数运行

二、变量

变量命名

  • 命名只能使用英文字母,数字和下划线,首字母不能以数字开头
  • 中间不能够有特殊字符,可以使用_下划线
  • 不能使用标点符号
  • 不能使用bash中的关键字
有效命名:
RUNOOB
LD_LIBRARY_PATH
_var
var2
无效命名:
?var=123
user*name=runoob
语句给变量赋值
for file in `ls /etc`for file in $(ls /etc)

使用变量

定义变量:
your_name="eagles"
使用变量:
echo $your_name
echo ${your_name}
建议使用{}号作边界
for skill in Ada Coffe Action Java; do
echo "I am good at ${skill}Script"
done
如果使用$skillScript,则将会输出空值

只读变量

#!/bin/bash
myUrl="http://www.google.com"
readonly myUrl
myUrl="http://www.runoob.com"
执行脚本后,显示只读变量无法修改

删除变量

#!/bin/sh
myUrl="http://www.runoob.com"
unset myUrl
echo $myUrl

变量种类

  • 本地变量:生效范围仅为当前shell进程;(其他shell,当前的子sehll进程均无效)
    • 变量赋值:name = “value”
  • 环境变量:生效范围为当前shell进程及子进程
    • 变量声明1:export name = “value”
    • 变量声明2:declare -x name = “value”
    • bash中有许多内建的变量环境:SHELL,PATH等等
  • 局部变量:生效范围为当前shell进程中某代码片断(通常指函数)
  • 位置变量: 2…来表示,让脚本在脚本代码中调用通过命令行传递给它的参数;
  • 特殊变量:? 0 * @ #
$1,$2,…:对应调用第1,第2等参数
$0:命令本身
$*:传递给脚本的所有参数(把所有参数当作整体)
$@:传递给脚本的所有参数
$#:传递给脚本的参数的个数
案例1:
myecho.sh
#!/bin/bash
echo "命令本身是:$0"
echo "第一个参数是:$1"
echo "第二个参数是:$2"
echo "一共有$#个参数"
echo "所有参数是:$@"案例2:判断所给文件的行数
linecount.sh
#!/bin/bash
linecount="$(wc -l $1|cut -d' ' -f1)"
或者linecount="$(wc -l $1|awk '{print $1}')"
echo "This file have ${linecount} lines"

三、数组

  • 语法格式
语法格式:array_name=(value1 ... valuen)
示例:
my_array=(A B C D)
array_name[0]=value0
array_name[1]=value1
array_name[2]=value2
  • 读取数组
读取数组:${array_name[index]}
获取数组中的所有元素:
my_array[0]=A
my_array[1]=B
my_array[2]=C
my_array[3]=D
echo "数组的元素为: ${my_array[*]}"
echo "数组的元素为: ${my_array[@]}"
  • 获取数组的长度
获取数组的长度:
my_array[0]=A
my_array[1]=B
my_array[2]=C
my_array[3]=D
echo "数组元素个数为: ${#my_array[*]}"
echo "数组元素个数为: ${#my_array[@]}"

四、算数运算

  • 运算符
+ ‐ * / % ** ...
增强赋值:
+=,‐=,*=,/=,%=
乘法符号有些场景中需要转义 : *\
bash有内建随机数生成器:$RANDOM
  • 完成算数运算
(1) let var(变量名)=算术表达式
(2) var=$[算术表达式]
(3) var=$((算术表达式))
(4) var=$(expr arg1 arg2 arg3 …) var=$(expr 1 + 2)
expr本身是一个命令,可以直接进行运算
[root@centos73 ~]# expr 1+2
1+2
[root@centos73 ~]# expr 1 + 2注意要空格才可以进行运算。乘法符号有些场景中需要转义,如 *。也就是expr这个命令后面跟的是3个参数
3
  • 练习题
练习1:计算/etc/passwd文件中第10个用户的第20个用户的ID之和
#!/bin/bash
userid1=$(sed -n '10p' | awk -F":" '{print $3}') /etc/passwd# userid1=`awk -F":" '{if (NR==10) print $3}' /etc/passwd`
userid2=$(sed -n '15p' | awk -F":" '{print $3}') /etc/passwd
userid_sum= $[$userid1 + $userid2]
echo '总和为$userid_sum'
练习2:传递两个文件路径参数给脚本,计算这两个文件之中所有空白行之和
#!/bin/bash
line1=`cat $1 |grep -c "^$"`
line2=`cat $2 |grep -c "^$"`
sum=$[$line1+$line2]
echo "总空行为$sum"
练习3:统计/etc/,/var/,/usr/目录下有多少目录和文件
#!/bin/bash
sum_etc=$(find /etc/ |wc -l)
sum_var=$(find /var/ |wc -l)
sum_usr=$(find /usr/ |wc -l)
sum_all=$[$sum_etc+$sum_var+$sum_usr]
echo $sum_all

五、条件测试

测试命令:test EXPERSSION

num1=100
num2=100
if test $[num1] -eq $[num2]
thenecho '两个数相等!'
elseecho '两个数不相等!'
fi

数值测试

‐gt:是否大于

‐ge:是否大于等于

‐eq:是否等于

‐ne:是否不等于

‐lt:是否小于

‐le:是否小于等于

练习题,比较两个数的大小

[root@localhost ~]# cat diff.sh
#!/bin/bash
read -p "请输入两个整数" num1 num2
if [ $num1 -gt $num2 ];thenecho "$num1 > $num2"
elif [ $num1 -lt $num2 ];thenecho "$num1 < $num2"
elseecho "$num1 = $num2"
fi

字符串测试

==:是否等于
>:是否大于
<:是否小于
!=:是否不等于
=~:左侧字符串是否能够被右侧的PATTERN所匹配
Note:此表达式一般用于[[ ]]中
‐z “STRING”:测试字符串是否为空,空则为真,不空则为假
‐n “STRING”:测试字符串是否不空,不空则为真,空则为假

文件测试

简单的存在性测试:
‐a FILE :文件存在性测试,存在为真,否则为假
存在性及类型测试:
‐b FLIE:是否存在且为块设备文件;
‐c FILE:是否存在且为字符设备文件;
‐d FILE:是否存在且为目录文件;
‐f FILE:是否存在且为普通文件;
‐h FILE 或 ‐L FILE : 存在且为符号链接文件;
‐p FIEL :是否存在且为命名管道文件;
‐S FILE:是否存在且为套接文件;
文件权限测试:
‐r FILE:是否存在且可读
‐w FILE:是否存在且可写
‐x FILE:是否存在可执行
文件特殊权限测试:
‐u FILE:是否存在且拥有suid权限;
‐g FILE:是否存在且拥有sgid权限;
‐k FILE:是否存在且拥有sticky权限;
文件大小测试:
‐s FILE:是否存在且非空
文件是否打开:
‐fd:fd表示文件描述符是否已经打开且与某终端相关
‐N FILE:文件自动上一次读取之后是否被修改过;
‐O FILE:当前用户是否为文件的属主;
‐G FILE:当前有效用户是否为文件数组;
双目测试:
FILE1 ‐ef FILE2 :FILE1与FILE2是否指向同一个设备上的相同inode
FILE1 ‐nt FILE2:FILE1是否新于FILE2
FILE1 ‐ot FILE2:FILE1是否旧于FILE2

组合测试

逻辑运算符:
&&代表的意思是当前一个命令执行成功时会继续执行后续的命令,当前一个命令执行失败的时候不会执行后续的命令
||代表的意思是当前一个命令执行成功时不会继续执行后续的命令,当前一个命令执行失败的时候会执行后续的命令
第一种方式:
COMMAND1 && COMMAND2
COMMAND1 || COMMAND2
! COMMAND
第二种方式:
EXPRESSION1 ‐a EXPRESSION2
EXPRESSION1 ‐o EXPRESSION2
! EXPRESSION
Note:必须使用测试命令进行

六、选择执行

  • 单分支选择结构
if 判断条件;then
条件为真的分支代码
fi
  • 双分支选择结构
if 判断条件;then
条件为真的分支代码
else
条件为假的分支代码
fi
  • 多分支选择结构
if 判断条件;then
条件为真的分支代码
elif 判断条件;then
条件为真的分支代码
else
条件为假的分支代码
fi
  • 练习题
练习1:判断两个数是否相等Note:if经常会与test命令一起使用
练习2:判断用户是否存在,如果不存在添加用户,并设置密码和用户相同
#!/bin/bash
#read -p "请输入用户" $1
if [ $# -eq 1 ]
then
echo "arg less than 1"
exit 1	# 可以用echo?查看退出码,方便检查
fi
id $1 &> /dev/null
if [ $? -eq 0 ]
then
echo "用户已存在"
exit 2
else
useradd $1 && echo "$1" | passwd --stdin $1 &> /dev/null
fi

七、用户交互

read命令

  • 常用选项:

    • ‐a:将内容读入到数组中
      • echo ‐n “Input muliple values into an array:”
      • read ‐a array
      • echo “get ${#array[@]} values in array”
    • ‐d : 表示delimiter,即定界符,例如输入为 hello m,有效值为“hello”,请注意m前面的空格等会被删除
    • ‐e :只用于互相交互的脚本
    • ‐n : 用于限定最多可以有多少字符可以作为有效读入
    • ‐p :用于给出提示符,例如:echo –n “…“来给出提示符,可以使用read –p ‘… my promt?’value的方式只需一个语句来表示
    • ‐r :特殊字符生效(/n等),也应采用‐r选项。
    • ‐s : 对于一些特殊的符号不打印的情况
    • ‐t :用于表示等待输入的时间(s),等待时间超过,将继续执行后面的脚本
  • 练习1:提示为:“input your name:”,输入姓名后,进行输出

#!/bin/bash
read ‐p "input your name:" name
read -p "input your name:" pd
res=`mysql -e "select count(*) from test.t_login where username=${name} and password=${pd}"| sed -n "2p"` 2> /dev/null
#echo "${res}"
mysql_status=`mysqladmin ping &> /dev/null`
if [ $? -ne 0 ];then
echo"mysql error"
exit 100
fi
if [ $res -eq 0 ]
then
echo "登陆失败"
exit 1 
else
echo ${name}
echo "登录成功"
exit 0
fi
  • 练习2:读取test.txt文本,输出格式为: linecount:context
test.txt
aaa
bbb
ccc
#!/bin/bash
nl test.txt | awk '{print $1":"$2}'#!/bin/bash
count=1
cat test.txt| while read line 
do
echo "$count:$line"
count=$[ $count+1 ]
donecat
echo "Finish"

八、循环语句

for循环

  • 循环体:需要执行的语句,可能执行n遍
  • 语法
for 变量名 in 列表;do
循环体
done
  • 执行机制:依次将列表中的元素赋值给“变量名”;每次赋值后执行一次循环体;直到列表中的元素耗尽,循环结束
  • 练习题1:创建用户user1‐user10家目录,并且在user1‐10家目录下创建1.txt‐10.txt
#!/bin/bash
for i in {1..10};do
mkdir /home/user$i
for i in (seq 1 10);do
touch /home/user$i/user$i.txt
done
done
练习题2:列出/var/目录下各个子目录占用磁盘大小
#!/bin/bash
for i in `ls /var/`
do
path="/var/$i"
if [ -d $path ]
then 
du -sh $path
fi
done
  • 练习题2:批量测试地址是否在线
[root@localhost ~]# cat ping.sh
#!/bin/bash
for i in {1..255}
do
ping -c2 -W1 192.168.175.$i &> /dev/null
[ $? -eq 0 ] && echo 192.168.175.$i >> ./host.txt
done

while循环

  • 语法
while 测试条件;do
循环体
done
  • 经典使用,遍历一个文件
#!/bin/bash
while read a;do
echo $a
done < /datas/6files
  • 练习题1:计算1+2+…10
#!/bin/bash
i=1
while ((i<=10))
do
let sum+=i
let ++i
done
echo $sum
  • 练习题2,猜随机数游戏
[root@localhost ~]# cat ran.sh
#!/bin/bash
ran=`echo $((RANDOM%100+1))`
i=0
while true
doread -p "请输入你要猜的数字" numlet i++if [ $num -gt $ran ];thenecho "你猜测的数字大了"if [ $num -lt $ran ];thenecho "你猜的数字小了"elseecho "恭喜你,猜对了!"echo "你一共猜了$i次"exitfi
done

until循环

  • while的是条件是测真值,until的条件式测假值
  • 语法
until 条件测试;do
循环体
done
  • 练习1:99乘法表
#!/bin/bash
a=1
b=1
until ((a > 9));do
until ((b > a));do
let "c=a*b" #声明变量c
echo -n "$a*$b=$c"	# -n的意思是不换行
let b++
done
let a++
let b=1	#因为每个乘法表都是1开始乘,所以b要重置
echo "" #显示到屏幕换行
done

九、函数

  • 语法
function FUNNAME(){
函数体
返回值
}
FUNNME #调用函数
  • 实例1
#!/bin/bash
demoFun(){
echo '这是我的第一个 shell 函数!'
}
echo "‐‐‐‐‐函数开始执行‐‐‐‐‐"
demoFun
echo "‐‐‐‐‐函数执行完毕‐‐‐‐‐"
  • 带返回值并且调用返回值
funWithReturn(){
echo "这个函数会对输入的两个数字进行相加运算..."
echo "输入第一个数字: "
read aNum
echo "输入第二个数字: "
read anotherNum
echo "两个数字分别为 $aNum$anotherNum !"
return $(($aNum+$anotherNum))
}
funWithReturn
echo "输入的两个数字之和为 $? !"
#可以使用$?来获取返回值
  • 函数参数
funWithParam(){
echo "第一个参数为 $1 !"
echo "第二个参数为 $2 !"
echo "第十个参数为 $10 !"
echo "第十个参数为 ${10} !"
echo "第十一个参数为 ${11} !"
echo "参数总数有 $# 个!"
echo "作为一个字符串输出所有参数 $* !"
}
funWithParam 1 2 3 4 5 6 7 8 9 34 73
注意,$10 不能获取第十个参数,获取第十个参数需要${10}。当n>=10时,需要使用${n}来获取参数

十、调试脚本

  • -x : 在执行时显示参数和命令;
  • +x:禁止调试
  • -v:当命令行进行读取时显示输入;
  • +v:禁止打印输入。
    • n:检测脚本中的语法错误
      在这里插入图片描述
      在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

十一、环境配置

bash配置文件

  • 生效范围分类

    • 全局配置:
      • /etc/bashrc
      • /etc/profile
      • /etc/profile.d/*.sh
    • 个人配置
      • ~/.bash_profile
      • ~/.bashrc
  • 功能分类

    • profile类:为交互式的shell提供配置
    • bashrc类:为非交换式的shell提供配置
  • shell登录

    • 交互式登录:su - USERNAME
    • /etc/profile –> /etc/profile.d/*.sh –> ~/.bash_profile –> ~/.bashrc –> /etc/bashrc
    • 非交换式登录:su USERNAME
  • 编辑配置文件定义的新设置的生效方式

    • 重新启动shell进程
    • 使用source命令

案例,开机显示系统信息脚本

[root@localhost ~]# cat os.sh
#!/bin/bash
yum install -y net-tools &> /dev/null
wangka=`ip a | grep ens | head -1 | cut -d: -f2`
System=$(hostnamectl | grep System | awk '{print $3,$4,$5}')
Kernel=$(hostnamectl | grep Kernel | awk -F: '{print $2}')
Virtualization=$(hostnamectl | grep Virtualization| awk '{print $2}')
Statichostname=$(hostnamectl | grep Static|awk -F: '{print $2}')
Ens32=$(ifconfig $wangka | awk 'NR==2 {print $2}')
Lo=$(ifconfig lo0 | awk 'NR==2 {print $2}')
NetworkIp=$(curl -s icanhazip.com)
echo "当前系统版本是:$System"
echo "当前系统内核是:$Kernel"
echo "当前虚拟平台是:$Virtualization"
echo "当前主机名是:$Statichostname"
echo "当前网卡$wangka的地址是:$Ens32"
echo "当前lo0接口的地址是:$Lo"
echo "当前公网地址是:$NetworkIp"
[root@localhost ~]# bash os.sh
当前系统版本是:CentOS Linux 7
当前系统内核是: Linux 3.10.0-693.el7.x86_64
当前虚拟平台是:vmware
当前主机名是: localhost.localdomain
当前网卡 ens33的地址是:192.168.80.129
当前lo0接口的地址是:127.0.0.1
当前公网地址是:112.4.252.23

案例,监控httpd进程

##################################################################

#############################################################

#需求:

#1.每隔10s监控httpd的进程数,若进程数大于等于500,则自动重启Apache服务,并检测服务是否重启成功

#2.若未成功则需要再次启动,若重启5次依旧没有成功,则向管理员发送告警邮件(使用echo输出已发送即可),并退出检测

#3.如果启动成功,则等待1分钟后再次检测httpd进程数,若进程数正常,则恢复正常检测(10s一次),否则放弃重启并向管理员发送告警邮件,并退出检测

##################################################################

##############################################################

#!/bin/bash
function check_httpd_process_number() {
process_num=`ps -ef | grep httpd| wc -l`if [ $process_num -gt 50 ];thensystemctl restart httpd &> /dev/null# 重启五次httpd确保服务启动systemctl status httpd &> /dev/nullif [ $? -ne 0 ];thennum_restart_httpd=0while true;dolet num_restart_httpd++systemctl restart httpd &> /dev/nullsystemctl status httpd &> /dev/null[ $? -eq 0 ] && break[ $num_restart_httpd -eq 6 ] && breakdonefi# 判断重启服务的结果systemctl status httpd &> /dev/null[ $? -ne 0 ] && echo "apache未正常重启,已发送邮件给管理员" && return 1sleep 60return 0# 再次判断进程是否正常process_num=`ps -ef | grep httpd| wc -l`if [ $process_num -gt 50 ] ;thenecho "apache经过重启进程数依然大于50"return 1elsereturn 0fielseecho "进程数小于50"sleep 10return 0
fi
}# 每十秒钟执行一次函数,检查进程是否正常
while true;do
check_httpd_process_number
[ $? -eq 1 ] && exit
done# while true;do ab -c 10000 -n 20000 http://127.0.01/;done

案例,统计两个目录

#!/bin/bash
# server1的文件在/test/目录中,server2的文件在/root/demo中,通过md5值来判断文件一致性,最终输出相同文件以及各自的不同文件
#定义两个数组的索引
point1=0
point2=0
# 将server1上的文件的散列值记录到数组当中
for i in `ls /root/demo`;domd5=`md5sum /root/demo/$i |awk '{print $1}'`arrar1[$point1]=$md5:$iecho ${arrar1[$point1]}let point1++
done
echo "/root/demo的文件"
# 将server2上的文件的散列值记录到数组当中
for i in `ls /test`;domd5=`md5sum /test/$i |awk '{print $1}'`arrar2[$point1]=$md5:$iecho ${arrar2[$point2]}let point2++
done# 找出相同文件以及server1上的独立文件,server1的每个文件都和server2上进行比较
echo "------------------------"
for i in ${arrar1[@]};dofor j in ${arrar2[@]};dotemp_flag=0	#定义一个标志位,表示没有找到相同的文件server1_md5=`echo $i| awk -F: '{print $1}'`server2_md5=`echo $j| awk -F: '{print $1}'`server1_filename=`echo $i| awk -F: '{print $2}'`server2_filename=`echo $j| awk -F: '{print $2}'`if [ $server1_md5 == $server2_md5 ];thenecho -e "两边共同文件\t\t\t$server1_filename"temp_flag=1break	# 找到了相同的文件fidoneif [ $temp_flag -eq 0 ];thenecho -e "server1不同的文件\t\t\t$i"fi
done# 找出server2上的独立文件
for i in ${arrar2[@]};dofor j in ${arrar1[@]};dotemp_flag=0server1_md5=`echo $j| awk -F: '{print $1}'`server2_md5=`echo $i| awk -F: '{print $1}'`server1_filename=`echo $j| awk -F: '{print $2}'`server2_filename=`echo $i| awk -F: '{print $2}'`if [ $server1_md5 == $server2_md5 ];thentemp_flag=1break	# 找到了相同的文件fidoneif [ $temp_flag -eq 0 ];thenecho -e "server2不同的文件\t\t\t$i"fi
done

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/255315.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Matlab使用点云工具箱进行点云配准ICP\NDT\CPD

一、代码 主代码main.m&#xff0c;三种配准方法任选其一 % 读取点云文件 source_pc pcread(bun_zipper.ply); target_pc pcread(bun_zipper2.ply);% 下采样 ptCloudA point_downsample(source_pc); ptCloudB point_downsample(target_pc);% 配准参数设置 opt param_set…

基于YOLOv8的暗光低光环境下(ExDark数据集)检测,加入多种优化方式---自研CPMS注意力,效果优于CBAM ,助力自动驾驶(二)

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文主要内容:详细介绍了暗光低光数据集检测整个过程&#xff0c;从数据集到训练模型到结果可视化分析&#xff0c;以及如何优化提升检测性能。 &#x1f4a1;&#x1f4a1;&#x1f4a1;加入 自研CPMS注意力 mAP0.5由原始的0.682提升…

大型语言模型(LLM)的优势、劣势和风险

最近关于大型语言模型的奇迹&#xff08;&#xff09;已经说了很多LLMs。这些荣誉大多是当之无愧的。让 ChatGPT 描述广义相对论&#xff0c;你会得到一个非常好&#xff08;且准确&#xff09;的答案。然而&#xff0c;归根结底&#xff0c;ChatGPT 仍然是一个盲目执行其指令集…

使用UMAP降维可视化RAG嵌入

大型语言模型&#xff08;LLMs&#xff09;如 GPT-4 已经展示了出色的文本理解和生成能力。但它们在处理领域特定信息方面面临挑战&#xff0c;比如当查询超出训练数据范围时&#xff0c;它们会产生错误的答案。LLMs 的推理过程也缺乏透明度&#xff0c;使用户难以理解达成结论…

【Linux】make和Makefile

目录 make和Makefile make和Makefile 我们使用vim编辑器的时候&#xff0c;在一个文件里写完代码要进行编译&#xff0c;要自己输入编译的指令。有没有一种可以进行自动化编译的方法——makefile文件&#xff0c;它可以指定具体的编译操作&#xff0c;写好makefile文件&#x…

新零售的升维体验,摸索华为云GaussDB如何实现数据赋能

新零售商业模式 商业模式通常是由客户价值、企业资源和能力、盈利方式三个方面构成。其最主要的用途是为实现客户价值最大化。 商业模式通过把能使企业运行的内外各要素整合起来&#xff0c;从而形成一个完整的、高效率的、具有独特核心竞争力的运行系统&#xff0c;并通过最…

【el-tree 文字过长处理方案】

文字过长处理方案 一、示例代码二、关键代码三、效果图 一、示例代码 <divstyle"height: 600px;overflow: auto"class"text item"><el-treeref"tree":data"treeData":props"defaultProps"class"filter-tree&…

fast.ai 深度学习笔记(四)

深度学习 2&#xff1a;第 2 部分第 8 课 原文&#xff1a;medium.com/hiromi_suenaga/deep-learning-2-part-2-lesson-8-5ae195c49493 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 来自 fast.ai 课程的个人笔记。随着我继续复习课程以“真正”理解它&#xff0c;这…

6.0 Zookeeper session 基本原理详解教程

客户端与服务端之间的连接是基于 TCP 长连接&#xff0c;client 端连接 server 端默认的 2181 端口&#xff0c;也就 是 session 会话。 从第一次连接建立开始&#xff0c;客户端开始会话的生命周期&#xff0c;客户端向服务端的ping包请求&#xff0c;每个会话都可以设置一个…

数据分析基础之《pandas(6)—高级处理》

一、缺失值处理 1、如何处理nan 两种思路&#xff1a; &#xff08;1&#xff09;如果样本量很大&#xff0c;可以删除含有缺失值的样本 &#xff08;2&#xff09;如果要珍惜每一个样本&#xff0c;可以替换/插补&#xff08;计算平均值或中位数&#xff09; 2、判断数据是否…

爬虫练习——动态网页的爬取(股票和百度翻译)

动态网页也是字面意思&#xff1a;实时更新的那种 还有就是你在股票这个网站上&#xff0c;翻页。他的地址是不变的 是动态的加载&#xff0c;真正我不太清楚&#xff0c;只知道他是不变的。如果用静态网页的方法就不可行了。 静态网页的翻页&#xff0c;是网址是有规律的。 …

【正在更新】从零开始认识语音识别:DNN-HMM混合系统语音识别(ASR)原理

摘要 | Abstract TO-BE-FILLED 1.前言 | Introduction 近期想深入了解语音识别(ASR)中隐马尔可夫模型(HMM)和深度神经网络-隐马尔可夫(DNN-HMM)混合模型&#xff0c;但是尽管网络上有许多关于DNN-HMM的介绍&#xff0c;如李宏毅教授的《深度学习人类语言处理》[1]&#xff0c;…

office 2021安装教程(官方自动批量激活,无付费)

全程不需要第三方软件&#xff0c;所有用到的工具都是微软官方的&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; 基于KMS的 GVLK&#xff1a;https://learn.microsoft.com/zh-cn/deployoffice/vlactivation/gvlks 首先我们需要去下载 office 软件部署工具&a…

二、数据结构

链表 单链表 https://www.acwing.com/problem/content/828/ #include<iostream> using namespace std; const int N 1e5 10; //head:头节点的指向 e[i]:当前节点i的值 ne[i]:当前节点i的next指针 idx:当前存储的点 int head, e[N], ne[N], idx;//初始化 void i…

01动力云客之环境准备+前端Vite搭建VUE项目入门+引入Element PLUS

1. 技术选型 前端&#xff1a;Html、CSS、JavaScript、Vue、Axios、Element Plus 后端&#xff1a;Spring Boot、Spring Security、MyBatis、MySQL、Redis 相关组件&#xff1a;HiKariCP&#xff08;Spring Boot默认数据库连接池&#xff09;、Spring-Data-Redis&#xff08;S…

【多模态大模型】视觉大模型SAM:如何使模型能够处理任意图像的分割任务?

SAM&#xff1a;如何使模型能够处理任意图像的分割任务&#xff1f; 核心思想起始问题: 如何使模型能够处理任意图像的分割任务&#xff1f;5why分析5so分析 总结子问题1: 如何编码输入图像以适应分割任务&#xff1f;子问题2: 如何处理各种形式的分割提示&#xff1f;子问题3:…

43.1k star, 免费开源的 markdown 编辑器

简介 项目名&#xff1a; MarkText-- 简单而优雅的开源 Markdown 编辑器 Github 开源地址&#xff1a; https://github.com/marktext/marktext 官网&#xff1a; https://www.marktext.cc/ 支持平台&#xff1a; Linux, macOS 以及 Windows。 操作界面&#xff1a; 在操作界…

vueRouter中Hash模式和History模式有什么区别

VueRouter是Vue.js官方推荐的前端路由库&#xff0c;它提供了一种方便的方式来构建单页应用&#xff08;SPA&#xff09;。在使用VueRouter时&#xff0c;我们可以选择不同的路由模式&#xff0c;其中最常见的是Hash模式和History模式。本文将深入探讨这两种模式的区别&#xf…

资产管理系统技术架构设计与实现

资产管理系统在现代金融领域扮演着至关重要的角色。它不仅帮助机构有效管理和优化资产配置&#xff0c;还提供了风险控制、绩效评估等功能。本文将探讨资产管理系统的技术架构设计与实现&#xff0c;以帮助读者深入了解该系统&#xff0c;并为其开发和部署提供参考。 1. 概述资…

【算法与数据结构】496、503、LeetCode下一个更大元素I II

文章目录 一、496、下一个更大元素 I二、503、下一个更大元素II三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、496、下一个更大元素 I 思路分析&#xff1a;本题思路和【算法与数据结构】739、LeetCode每日温度类似…