shell命令编写

文章详细介绍了Bashshell中的基本操作,如使用find命令统计文件数量,设置环境变量,以及字符串处理(单引号、双引号和反引号的区别)。此外,还展示了数组的使用、文件复制、循环结构和动态生成并执行命令的示例。
摘要由CSDN通过智能技术生成

 1.

  1 #!/bin/bash 
  2 
  3 directory_path="/txh"
  4 
  5 # 使用 find 命令查找指定路径下的文件,并使用 wc 命令统计行数(即文件个数)
  6 
  7 file_count=$(find "directory_path" -type f | wc -l)
  8 
  9 
 10 echo "在路径$directory_path下的文件个数是: $file_count"   

 解释一下最关键的 -type f

  • -type: 用于指定要查找的文件类型。
  • f: 表示普通文件。这包括文本文件、二进制文件等,但不包括目录、设备文件、符号链接等其他类型的文件。

find 是一个在Unix和类Unix系统中用于在目录树中查找文件和目录的强大命令。它能够根据各种条件搜索文件,并执行相应的操作。

find 命令的基本语法如下:

bash

find [起始目录] [匹配条件] [执行操作]

  • 按文件名搜索:

    find /path/to/search -name "filename"

2.

set

env

如何设置环境变量呢?

export 

4.

单引号(')

单引号用于创建字面量字符串,其中的内容被视为精确的文本。在单引号内部,特殊字符(比如变量、通配符和命令替换)通常不会被解释或扩展。例如:

echo 'Hello, $USER'

在这个例子中,$USER 不会被解释为当前用户,而是作为普通字符串输出。

双引号(")

双引号用于创建字符串,并允许解释其中的变量和特殊字符。在双引号内,变量会被替换为其值,而特殊字符会被扩展。例如

greeting="Hello, $USER";echo "$greeting" 

在这里,$USER 被解释为当前的用户名,并被替换成实际的用户名。

 在这里$USER会变成用户的名字,所以是root

反引号(`)

反引号用于执行命令替换,将命令的输出结果赋值给变量。例如:

current_date=`date` echo "今天是:$current_date"

在这个例子中,date 命令的输出被赋值给 current_date 变量。

需要注意的是,反引号在较新的Shell版本中逐渐被 $() 替代,功能相似但更易读且嵌套更方便:

5.

#!/bin/bash

directory_path="/path/to/your/directory"

# 获取目录中的所有文件
files=("$directory_path"/*)

# 删除前10个文件
for ((i=0; i<10 && i<${#files[@]}; i++)); do
    rm "${files[$i]}"
    echo "已删除文件:${files[$i]}"
done

echo "成功删除 $i 个文件。"

6.

 2 #定义存储联系人的数组
  3 contacts=()
  4 
  5 #使用while循环添加联系人
  6 while true; do
  7   read -p "请输入联系人姓名(输入exit结束) : " name
  8 
  9   if [ "$name" == "exit" ]; then
 10      break
 11   fi
 12 
 13   read -p "请输入联系人电话: " phone
 14 
 15   #将联系人信息添加到数组中
 16   contact="姓名: $name,电话: $phone"
 17   contacts+=("$contact")
 18 
 19 done
 20 
 21 echo "通讯录: "
 22 for contact in "${contacts[@]}"; do
 23     echo "$contact"
 24 done               
  1. #!/bin/bash: 这是 shebang 行,指定了脚本使用的解释器。#!/bin/bash 表示脚本将由 Bash 解释器执行。

  2. contacts=(): 这行创建了一个名为 contacts 的空数组。这是 Bash 中定义数组的方式。

  3. while true; do ... done: 这是一个无限循环的开始。while true 会一直循环执行,因为条件始终为真。循环中的命令将一直执行,直到遇到 break 为止。

  4. read -p "请输入联系人姓名(输入exit结束添加): " name: read 命令用于从标准输入读取用户输入,并将其存储在变量中。-p 选项用于在用户输入前显示提示消息。在这里,用户输入的姓名将被存储在 $name 变量中。

  5. if [ "$name" == "exit" ]; then break; fi: 这是一个条件语句,使用 if 进行条件判断。[ "$name" == "exit" ] 检查变量 $name 是否等于 "exit"。如果是,就执行 break 命令退出循环。

  6. read -p "请输入联系人电话: " phone: 类似于前面的 read 命令,用于接收用户输入的电话号码,并将其存储在 $phone 变量中。

  7. contact="姓名: $name, 电话: $phone": 这行创建了一个字符串变量 contact,其中包含联系人姓名和电话信息。这里使用了变量替换,将 $name$phone 的值嵌入到字符串中。

  8. contacts+=("$contact"): 这是将字符串 $contact 添加到数组 contacts 的语法。+= 表示追加。

  9. echo "通讯录:": echo 命令用于打印文本到标准输出。在这里,它打印了通讯录的标题。

  10. for contact in "${contacts[@]}"; do echo "$contact"; done: 这是一个 for 循环,用于遍历数组 contacts 中的每个元素。${contacts[@]} 表示整个数组。循环中的命令 echo "$contact" 打印每个联系人的信息。

 7.

#!/bin/bash

# 获取目标目录
target_directory="$1"

# 遍历输入参数中的文件,并将其复制到目标目录
for file in "${@:2}"; do
    # 检查文件是否存在
    if [ -e "$file" ]; then
        # 复制文件到目标目录
        cp "$file" "$target_directory/"
        echo "已复制文件 '$file' 到目录 '$target_directory/'"
    else
        echo "警告: 文件 '$file' 不存在,跳过该文件"
    fi
done

echo "复制完成"

./copy_files.sh /目标目录 文件1 文件2 文件3
 

8.

#!/bin/bash

# 定义包含10个城市名称的数组
cities=("城市1" "城市2" "城市3" "城市4" "城市5" "城市6" "城市7" "城市8" "城市9" "城市10")

# 遍历数组并打印每个城市名称
for city in "${cities[@]}"; do
    echo "$city"
done

 9.

该脚本动态构建一个包含从命令行参数的数量递减到 1 的数字序列的 echo 命令,并通过 eval 命令执行这个构建的 echo 命令,从而实现以逆序打印数字。

10.

#!/bin/bash

# 接收用户输入的字符串
read -p "请输入字符串: " input_string

# 接收用户输入的n和m
read -p "请输入要提取的起始位置n: " n
read -p "请输入要提取的结束位置m: " m

# 使用cut命令提取子串
result=$(echo "$input_string" | cut -c $n-$m)

# 显示提取的子串
echo "提取的子串为: $result"

cut的用法:

其中 OPTION 是一些选项,FILE 是输入文件的名称。如果没有指定文件,则 cut 从标准输入读取数据。

以下是一些常用的 cut 命令选项:

  • -c, --characters=LIST:指定要剪切的字符范围。例如,-c 1-5 表示剪切第1到第5个字符。

  • -f, --fields=LIST:指定要剪切的字段范围,字段以制表符或空格分隔。例如,-f 2,4 表示剪切第2和第4个字段。

  • -d, --delimiter=DELIM:指定字段分隔符,默认为制表符。

  • --complement:补集,表示不剪切指定的部分,而是保留其他部分。

  • --output-delimiter=STRING:指定输出时使用的分隔符。

实验题:

#!/bin/bash

# Function to draw the progress bar
drawProgressBar() {
    local progress=$1
    local total=$2
    local bar_length=50
    local filled_length=$((progress * bar_length / total))
    local empty_length=$((bar_length - filled_length))

    # Create the progress bar string
    local progress_bar=$(printf "[%s%s]" $(printf "#%.0s" $(seq 1 $filled_length)) $(printf " %.0s" $(seq 1 $empty_length)))

    # Print the progress bar
    printf "\r%s %d%%" "$progress_bar" $((progress * 100 / total))
}

# Example usage
total_steps=100

for ((i=1; i<=total_steps; i++)); do
    # Perform some task here
    sleep 0.1

    # Update the progress bar
    drawProgressBar $i $total_steps
done

# Print a newline to separate the progress bar from the next command prompt
echo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

乖的小肥羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值