shell脚本接收n个参数,将他们保存进数组,写法,详细示例给一下,谢谢
时间: 2023-03-04 10:56:12 浏览: 192
以下是一个示例的 shell 脚本,它将接收 n 个参数并将它们保存到数组中:
```bash
#!/bin/bash
# 创建一个空数组
args=()
# 循环读取所有参数
for arg in "$@"
do
# 将参数添加到数组末尾
args+=("$arg")
done
# 打印数组中的所有元素
for arg in "${args[@]}"
do
echo "$arg"
done
```
首先,脚本创建一个名为 `args` 的空数组。然后,它使用 `for` 循环读取所有参数并将它们添加到数组末尾。最后,脚本使用另一个 `for` 循环打印数组中的所有元素。
使用示例:
```bash
./script.sh apple banana orange
```
输出:
```
apple
banana
orange
```
这个示例将命令行中的三个参数 `apple`,`banana` 和 `orange` 存储到 `args` 数组中,并按顺序打印了这些参数。
相关问题
shell脚本传入多个不固定参数的写法
在 shell 脚本中,可以通过 `$1`、`$2`、`$3` 等变量来获取传入的参数。如果要传入多个不固定数量的参数,可以使用特殊的变量 `$@` 或者 `$*`。
下面是一个示例脚本,可以接收任意数量的参数,并将它们依次输出:
```
#!/bin/bash
echo "参数个数为: $#"
echo "参数列表: $@"
```
在执行该脚本时,可以传入任意数量的参数:
```
$ ./test.sh a b c d e
```
输出结果为:
```
参数个数为: 5
参数列表: a b c d e
```
注意,使用 `$@` 或者 `$*` 变量时,参数之间会自动用空格分隔开,而且会将参数列表视为一个整体。如果需要对每个参数进行单独操作,可以使用 `"$@"` 或者 `"$*"`,将参数列表作为多个独立的字符串处理。
shell规范写法示例
Shell脚本遵循一定的结构和规范,以提高可读性和一致性。下面是一些基本的shell规范写法示例:
1. **注释**:通常使用 `#` 或 `<!-- -->` 注释单行内容,例如:
```sh
# 这是一个单行注释
echo "Hello, World!" # 单行命令后也可跟注释
```
2. **空格和缩进**:保持良好的缩进习惯,比如使用4个空格而不是制表符:
```sh
if [ "$condition" == true ]; then
do_something
fi
```
3. **变量名**:采用下划线 `_` 分隔单词,如 `my_variable_name`:
```sh
my_variable="example_value"
```
4. **命令分组**:使用括号 `()` 来明确操作顺序,如 `(command1 && command2)`:
```sh
(ls -l && mkdir new_directory) || echo "Failed to create directory."
```
5. **函数定义**:使用 `function` 关键字,例如:
```sh
function hello() {
echo "Hello, $1!"
}
hello world
```
6. **错误处理**:尽量使用标准的错误检查和捕获机制,如 `set -e` 和 `if [[ ... ]]; then ... else ... fi`。
7. **文件I/O**:打开文件时加上描述,如 `echo "message" > /path/to/file.txt`。
8. **清晰的命名**:命令、函数和变量名应反映其作用,避免使用太短或模糊不清的名称。
阅读全文