感谢支持
我们一直在努力

Shell脚本传递命令行参数

在Windows下是使用 %1 %2 %3
而在Linux下是使用   $1 $2  $3
——————-
如:
1.某bat文件
cd ..\data
@java -classpath ..\lib\hsqldb.jar org.hsqldb.util.DatabaseManager %1 %2 %3 %4 %5 %6 %7 %8 %9

2.某sh文件
#!/bin/sh
cd ../data
java -cp ../lib/hsqldb.jar org.hsqldb.util.DatabaseManager $1 $2 $3 $4 $5 $6 $7 $8 $9
——————-
其中, $0就是脚本文件的名字,$1是第一个参数,$2为第2个…
$9以后就需要打括号了,如${10},${11},${12}…

==========================================================

1.
 #————————————————————————-
 9 # 强烈注意,在赋值的前后一定不要有空格
10 # 如果有空格会发生什么?
11
12 #  如果”VARIABLE =value”,
13 #              ^
14 #+ 脚本将尝试运行一个”VARIABLE”的命令,带着一个”=value”参数.
15
16 #  如果”VARIABLE= value”,
17 #               ^
18 #+ script tries to run “value” command with
18 #+ 脚本将尝试运行一个”value”的命令,带着
19 #+ the environmental variable “VARIABLE” set to “”.
19 #+ 一个被赋成””值的环境变量”VARIABLE”.
20 #————————————————————————-


2.
################################Start Script#######################################
 1 #!/bin/bash
 2 # “裸体”变量
 3
 4 echo
 5
 6 # 变量什么时候是”裸体”的,比如前边少了$的时候.
 7 # 当它被赋值的时候,而不是被引用的时候.
 8
 9 # 赋值
10 a=879
11 echo “The value of /”a/” is $a.”
12
13 # 使用let赋值
14 let a=16+5
15 echo “The value of /”a/” is now $a.”
16
17 echo
18
19 # 在for循环中
20 echo -n “Values of /”a/” in the loop are: “
21 for a in 7 8 9 11
22 do
23   echo -n “$a “
24 done
25
26 echo
27 echo
28
29 # 在read命令状态中
30 echo -n “Enter /”a/” “
31 read a
32 echo “The value of /”a/” is now $a.”
33
34 echo
35
36 exit 0
################################End Script#########################################

3.位置参数
就是从命令行中传进来的参数,$0, $1, $2, $3…
$0就是脚本文件的名字,$1是第一个参数,$2为第2个…,参见[1](有$0的说明),$9
以后就需要打括号了,如${10},${11},${12}…

shift命令重新分配位置参数,其实就是向左移动一个位置.
$1 <— $2, $2 <— $3, $3 <— $4, 等等.
老的$1将消失,但是$0(脚本名)是不会改变的.如果你使用了大量的位置参数,那么
shift命令允许你存取超过10个参数.虽然{}表示法也允许这样.

例:
#!/bin/sh
# we have less than 3 arguments. Print the help text:
if [ $# -lt 3 ] ; then
cat <
ren — renames a number of files using sed regular expressions
USAGE: ren ‘regexp’ ‘replacement’ files…
EXAMPLE: rename all *.HTM files in *.html:
 ren ‘HTM$’ ‘html’ *.HTM
HELP
 exit 0
fi
OLD=”$1″
NEW=”$2″
# The shift command removes one argument from the list of
# command line arguments.
shift
shift
# $* contains now all the files:
for file in $*; do
  if [ -f “$file” ] ; then
   newfile=`echo “$file” | sed “s/${OLD}/${NEW}/g”`
   if [ -f “$newfile” ]; then
    echo “ERROR: $newfile exists already”
   else
    echo “renaming $file to $newfile …”
    mv “$file” “$newfile”
   fi
  fi
done

讲解:这 是一个复杂一些的例子。让我们详细讨论一下。第一个if表达式判断输入命令行参数是否小于3个 (特殊变量$# 表示包含参数的个数) 。如果输入参数小于3个,则将帮助文字传递给cat命令,然后由cat命令将其打印在屏幕上。打印帮助文字后程序退出。 如果输入参数等于或大于3个,我们就将第一个参数赋值给变量OLD,第二个参数赋值给变量NEW。下一步,我们使用shift命令将第一个和第二个参数从 参数列表中删除,这样原来的第三个参数就成为参数列表$*的第一个参数。然后我们开始循环,命令行参数列表被一个接一个地被赋值给变量$file。接着我 们判断该文件是否存在,如果存在则通过sed命令搜索和替换来产生新的文件名。然后将反短斜线内命令结果赋值给newfile。这样我们就达到了我们的目 的:得到了旧文件名和新文件名。然后使用mv命令进行重命名。


4.
通常用” [ ] “ 来表示条件测试。注意这里的空格很重要。要确保方括号的空格。
[ -f “somefile” ]
判断是否是一个文件
[ -x “/bin/ls” ]
判断/bin/ls是否存在并有可执行权限
[ -n “$var” ]
判断$var变量是否有值
[ -e “somefile” ]:判断文件是否存在
[ -d “somefile” ]:判断是否为文件夹
[ -r “somefile” ]:判断文件是否可读
[ -w “somefile” ] :判断文件是否可写
[ -x “somefile” ]:判断文件是否可执行

[ “$a” = “$b” ]
判断$a和$a是否相等 


5. 双引号、单引号和反引号(后置引用)
双引号:阻止了所有在引号中的特殊字符的重新解释–包括变量名–但是$,`(后置引用)和/除外.保留$,作为特殊字符的意义,是为了能够在双引号中也能够正常地引用变量(“$var”)。
使用””来防止单词分割.[4]如果在参数列表中使用双引号,将使得双引号中的参数作为一个参数.即使双引号中的字符串包含多个单词(也就是包含空白部分),也不会变为多个参数。

单引号:
单引号操作总体上和””很像,但不允许引用变量.因为$的特殊含义被关闭了.在”中除了’,其他
字符都没有特殊的含义了.所以单引号比双引号严格. 因为即使是/,在”中都被关闭了,所以你想在”中显示’的含义,将得不到预期的效果.

反引号(后置引用):命令替换将会重新分配一个命令甚至是多个命令的输出;:它会将命令的输出如实地添加到另一个上下文中。使用命令替换的典型形式是使用后置引用(`…`). 后置引用形式的命令(就是被反引号括起来)将会产生命令行文本。
使用后置引用的意义在于:命令的输出可以被当成传递到另一个命令的参数, 或者保存到变量中, 甚至可以用来产生for循环的参数列表.

例如:
#!/bin/sh
file abc.zip    #执行并输出,但无法将其命令行输出赋值给一个变量
file_type=`file abc.zip`  #可执行并把其输出赋值给变量file_type

赞(0) 打赏
转载请注明出处:服务器评测 » Shell脚本传递命令行参数
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏