本文目录
- 第14章:处理用户输入
- linux 环境下shell编程里 case语句中调用函数怎么写
- 菜鸟请教linux case语句变量
- 关于Linux的case语句中字母大小写判断的问题
- Linux分条件执行命令 case $inp in 之后的
- Linux bash shell
- linux下的一个shell命令:大意是判断式 ,y时输出一个值;n时输出一个值 ,既不是y和n时,输出另外一个值
- Linux脚本中case语句的小问题
第14章:处理用户输入
向shell脚本传递数据的最基本方法是使用命令行参数。命令行参数允许在运行脚本时向命令行添加数据。
bash shell会将一些称为位置参数(positional parameter)的特殊变量分配给输入到命令行中的所有参数。这也包括shell所执行的脚本名称。位置参数变量是标准的数字: 1是第一个参数, 9。
可以用$0参数获取shell在命令行启动的脚本名。
这里存在一个潜在的问题。如果使用另一个命令来运行shell脚本,命令会和脚本名混在一起,出现在 0变量的实际字符串不仅仅是脚本名,而是完整的脚本路径时,变量$0就会使用整个路径。通过使用basename命令可以解决上述问题。
在bash shell中有些特殊变量,它们会记录命令行参数。
bash shell提供了特殊变量 $# 来表示脚本运行时携带的命令行参数的个数。可以在脚本中任何地方使用这个特殊变量,就跟普通变量一样。
有时候需要抓取命令行上提供的所有参数。 @ 可以用来访问所有的参数。这两个变量都能够在单个变量中存储所有的命令行参数。
*变量会将这些参数视为一个整体,而不是多个个体。
$@ 变量会将命令行上提供的所有参数当作同一字符串中的多个独立的单词。这样你能够遍历所有的参数值,得到每个参数。
@ 变量会单独处理每个参数。
bash shell提供了shift命令能够用来操作命令行参数。shift命令会根据它们的相对位置来移动命令行参数。在使用shift命令时,默认情况下它会将每个参数变量向左移动一个位置。所以,变量 2中,变量 1中,而变量 0的值,也就是程序名,不会改变)。
这个脚本通过测试第一个参数值的长度执行了一个while循环。当第一个参数的长度为零时,循环结束。测试完第一个参数后,shift命令会将所有参数的位置移动一个位置。
选项是跟在单破折线后面的单个字母,它能改变命令的行为。bash shell提供了几种处理选项的方法。
表面上看,命令行选择也没什么特殊的。在命令行上,它们紧跟在脚本之后,就跟命令行参数一样。实际上,可以像处理命令行参数一样处理命令行选项。
case语句会检查每个参数是不是有效选项。如果是的话,就运行对应case语句中的命令。
Linux中通过使用特殊字符( -- )来将选项和参数分开,该字符会告诉脚本何时选项结束以及普通参数何时开始。shell会用双破折线来表明选项列表结束。在双破折线之后,脚本就可以放心地将剩下的命令行参数当作参数,而不是选项来处理。
在遇到双破折线时,脚本用break命令来跳出while循环。由于过早地跳出了循环,我们需要再加一条shift命令来将破折线移出参数变量。
对于第一个测试,试试用一组普通的选项和参数来运行这个脚本。
结果说明在处理时脚本认为所有的命令行参数都是选项。接下来,使用双破折线来将命令行上的选项和参数划分开来。
当脚本遇到双破折线时,它会停止处理选项,并将剩下的参数都当作命令行参数。
有些选项会带上一个额外的参数值。在这种情况下,命令行看起来像下面这样。
当命令行选项要求额外的参数时,脚本必须能检测到并正确处理。
getopt命令是一个在处理命令行选项和参数时非常方便的工具。它能够识别命令行参数,从而在脚本中解析它们时更方便。
getopt命令可以接受一系列任意形式的命令行选项和参数,并自动将它们转换成适当的格式。它的命令格式如下:
optstring是这个过程的关键所在。它定义了命令行有效的选项字母,还定义了哪些选项字母需要参数值。首先,在optstring中列出你要在脚本中用到的每个命令行选项字母。然后,在每个需要参数值的选项字母后加一个冒号。getopt命令会基于你定义的optstring解析提供的参数。
optstring定义了四个有效选项字母:a、b、c和d。冒号(:)被放在了字母b后面,因为b选项需要一个参数值。当getopt命令运行时,它会检查提供的参数列表,并基于提供的optstring进行解析。注意,它会自动将-cd选项分成两个单独的选项,并插入双破折线来分隔行中的额外参数。
可以在脚本中使用getopt来格式化脚本所携带的任何命令行选项或参数,但用起来略微复杂。方法是用getopt命令生成的格式化后的版本来替换已有的命令行选项和参数。用set命令能够做到。set命令的选项之一是双破折线(--),它会将命令行参数替换成set命令的命令行值。然后,该方法会将原始脚本的命令行参数传给getopt命令,之后再将getopt命令的输出传给set命令,用getopt格式化后的命令行参数来替换原始的命令行参数,看起来如下所示:
现在原始的命令行参数变量的值会被getopt命令的输出替换,而getopt已经为我们格式化好了命令行参数。
与getopt不同,前者将命令行上选项和参数处理后只生成一个输出,而getopts命令一次只处理命令行上检测到的一个参数。处理完所有的参数后,它会退出并返回一个大于0的退出状态码。getopts命令的格式如下:
optstring值类似于getopt命令中的那个。有效的选项字母都会列在optstring中,如果选项字母要求有个参数值,就加一个冒号。要去掉错误消息的话,可以在optstring之前加一个冒号。getopts命令将当前参数保存在命令行中定义的variable中。
getopts命令会用到两个环境变量。如果选项需要跟一个参数值, OPTARG 环境变量就会保存这个值。 OPTIND 环境变量保存了参数列表中getopts正在处理的参数位置。
getopts命令知道何时停止处理选项,并将参数留给你处理。在getopts处理每个选项时,它会将OPTIND环境变量值增一。在getopts完成处理时,你可以使用shift命令和OPTIND值来移动参数。
在创建shell脚本时,显然可以控制具体怎么做。你完全可以决定用哪些字母选项以及它们的用法。但有些字母选项在Linux世界里已经有了某种程度的标准含义。
尽管命令行选项和参数是从脚本用户处获得输入的一种重要方式,但有时脚本的交互性还需要更强一些。bash shell提供了read命令来实现强交互命令输入。
read命令从标准输入(键盘)或另一个文件描述符中接受输入。在收到输入后,read命令会将数据放进一个变量。
echo命令使用了-n选项。该选项不会在字符串末尾输出换行符,允许脚本用户紧跟其后输入数据,而不是下一行。
使用read命令时,脚本很可能会一直苦等这脚本用户的输入。如果不管是否有数据输入,脚本都必须继续执行,你可以用-t选项来指定一个计时器。-t选项指定了read命令等待输入的秒数。当计数器过期后,read命令会返回一个非零退出状态码。
read命令包含了-p选项,允许你直接在read命令行指定提示符。
有时你需要从脚本用户处得到输入,但又在屏幕上显示输入信息。其中典型的例子就是输入的密码,但除此之外还有很多其他需要隐藏的数据类型。 -s 选项可以避免在read命令中输入的数据出现在显示器上(实际上,数据会被显示,只是read命令会将文本颜色设成跟背景色一样)。
输入提示符输入的数据不会出现在屏幕上,但会赋给变量,以便在脚本中使用。
最后,也可以用read命令在读取Linux系统上文件里保存的数据。每次调用read命令,它都会从文件中读取一行文本。当文件中再没有内容时,read命令会退出并返回非零退出状态码。其中最难的部分是将文件中的数据传给read命令。最常见的方法是对文件使用cat命令,将结果通过管道直接传给含有read命令的while命令。
while循环会持续通过read命令处理文件中的行,直到read命令以非零退出状态码退出。
linux 环境下shell编程里 case语句中调用函数怎么写
case ${i} in (1) function 参数1 参数2 ... ;; (2) ... ;; (...) ... ;;esac
dash manual 中的话:
The syntax of the case command is case word in pattern) list ;; ... esac
菜鸟请教linux case语句变量
第二句错了,a前面不要$ :read -p "please input example + - * /:" a
关于Linux的case语句中字母大小写判断的问题
换成这个试试字符类 大写这种写会被系统当成是一样的,不区分大小写。你也可以重置所有的本地化设置LC_ALL=C这样脚本的正则表达式可以正确识别
Linux分条件执行命令 case $inp in 之后的
在本例中的case中,变量$inp会逐个匹配1)、2)、3)等后面的选项,如果匹配成功就执行后面对应的语句。对于这一句:1)$HOME\...\a1 $$HOME\...\a2;;你应该没有给完整,“...”这个省略号在实际情况中是不可能出现的,应该对应实际的路径名字。这句活的意思是如果$inp的值是“$HOME\...\a1”,那么就执行“$$HOME\...\a2”(我觉得你这个命令也给错了,$$本省是一个变量,代表当前进行ID,估计原本该句是“$HOME\...\a2”,这里多了一个$。),
Linux bash shell
我试了下,把这样的写法也可以,不过好像你的格式有些问题,我这儿是可以的#!/bin/bashecho "input the data"read varcase $var in) echo "digit";;) echo "upper case letter";;) echo "lower case letter";;*) echo "error";;esac
linux下的一个shell命令:大意是判断式 ,y时输出一个值;n时输出一个值 ,既不是y和n时,输出另外一个值
呵呵,这是鸟哥书上关于if...then语句的例子。敲的时候仔细点就没事了。 个人觉得,其实这里用case语句做更方便,因为可以不用分别判断Y和y:case "$yn" in ) echo "ok, continue" ;; ) echo "oh, interrupt!" ;; *) echo "I don’t know" ;;esacexit
Linux脚本中case语句的小问题
按照你到思路,你的shell程序主要有两个错误:1,变量ft赋值错误;按照你的写法,ft的结果是:file /etc,因为等式右边加的是单引号,是字符串原样赋值,而并没有取到file这个命令到结果,正确写法是:ft=$(file "$NAME")2,第二个问题是格式问题,小问题。case语句中的备选项,如“$NAME:directory”,冒号后要加一个空格,因为file /etc这条命令的结果是/etc: directory,注意冒号后面是有一个空格的,所以case语句中到备选项格式要与之匹配。由于你写的程序有这两个错误,解释执行时,会转到case语句中到最后一项输出,即输出:/etc is Other file type我所说到已经经过本人亲自测试,所用系统为Fedora 12.希望能帮到你。