今天给各位分享位置参数有哪些linux的知识,其中也会对位置参数和形状参数进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
- 1、能把这个linux shell命令的每个参数给解释一下么
- 2、请问linux命令上的选项和参数两者有什么区别
- 3、我在做Linux的考试题目大家帮我答,感激不敬,3个名词解释题 指令取代:PAM(可插拔认证模块):位置参数:
- 4、编写linux shell一个脚本,要求如果第一个位置参数是合法目录,那么就把后面给出的各个位置参数所对应的文
- 5、linux中%什么意思
- 6、linux中的shell变量的种类及各种类的用处是什么?
1、能把这个linux shell命令的每个参数给解释一下么
问题描述:在linux shell中如何处理tail -n 10 access.log这样的命令行选项?
在bash中,可以用以下三种方式来处理命令行参数,每种方式都有自己的应用场景。
1,直接处理,依次对$1,$2,...,$n进行解析,分别手工处理;
2,getopts来处理,单个字符选项的情况(如:-n 10 -f file.txt等选项);
3,getopt,可以处理单个字符选项,也可以处理长选项long-option(如:--prefix=/home等)。
总结:小脚本手工处理即可,getopts能处理绝大多数的情况,getopt较复杂、功能也更强大。
1,直接手工处理位置参数
必须要要知道几个变量,
复制代码代码如下:
* $0 :即命令本身,相当于c/c++中的argv[0]
* $1 :第一个参数.
* $2, $3, $4 ... :第2、3、4个参数,依次类推。
* $# 参数的个数,不包括命令本身
* $@ :参数本身的列表,也不包括命令本身
* $* :和$@相同,但"$*" 和 "$@"(加引号)并不同,"$*"将所有的参数解释成一个字符串,而"$@"是一个参数数组。
手工处理方式能满足多数的简单需求,配合shift使用也能构造出强大的功能,但处理复杂选项时建议用下面的两种方法。
例子,(getargs.sh):
复制代码代码如下:
#!/bin/bash
if [ $# -lt 1 ]; then
echo "error.. need args"
exit 1
fi
echo "commond is $0"
echo "args are:"
for arg in "$@"
do
echo $arg
done
运行命令:
复制代码代码如下:
./getargs.sh 11 22 cc
commond is ./getargs.sh
args are:
11
22
cc
2,getopts (shell内置命令)
处理命令行参数是一个相似而又复杂的事情,为此,c提供了getopt/getopt_long等函数,c++的boost提供了options库,在shell中,处理此事的是getopts和getopt。
getopts/getopt的区别,getopt是个外部binary文件,而getopts是shell builtin。
复制代码代码如下:
[root@jbxue ~]$ type getopt
getopt is /usr/bin/getopt
[root@jbxue ~]$ type getopts
getopts is a shell builtin
getopts不能直接处理长的选项(如:--prefix=/home等)
关于getopts的使用方法,可以man bash 搜索getopts
getopts有两个参数,第一个参数是一个字符串,包括字符和“:”,每一个字符都是一个有效的选项,如果字符后面带有“:”,表示这个字符有自己的参数。getopts从命令中获取这些参数,并且删去了“-”,并将其赋值在第二个参数中,如果带有自己参数,这个参数赋值在“optarg”中。提供getopts的shell内置了optarg这个变变,getopts修改了这个变量。
这里变量$optarg存储相应选项的参数,而$optind总是存储原始$*中下一个要处理的元素位置。
while getopts ":a:bc" opt #第一个冒号表示忽略错误;字符后面的冒号表示该选项必须有自己的参数
例子,(getopts.sh):
复制代码代码如下:
echo $*
while getopts ":a:bc" opt
do
case $opt in
a ) echo $optarg
echo $optind;;
b ) echo "b $optind";;
c ) echo "c $optind";;
? ) echo "error"
exit 1;;
esac
done
echo $optind
shift $(($optind - 1))
#通过shift $(($optind - 1))的处理,$*中就只保留了除去选项内容的参数,可以在其后进行正常的shell编程处理了。
echo $0
echo $*
执行命令:
复制代码代码如下:
./getopts.sh -a 11 -b -c
-a 11 -b -c
11
3
b 4
c 5
5
./getopts.sh
3,getopt(一个外部工具)
具体用用法可以 man getopt
#-o表示短选项,两个冒号表示该选项有一个可选参数,可选参数必须紧贴选项,如-carg 而不能是-c arg
#--long表示长选项
例子,(getopt.sh):
复制代码代码如下:
#!/bin/bash
# a small example program for using the new getopt(1) program.
# this program will only work with bash(1)
# an similar program using the tcsh(1) script. language can be found
# as parse.tcsh
# example input and output (from the bash prompt):
# ./parse.bash -a par1 'another arg' --c-long 'wow!*\?' -cmore -b " very long "
# option a
# option c, no argument
# option c, argument `more'
# option b, argument ` very long '
# remaining arguments:
# -- `par1'
# -- `another arg'
# -- `wow!*\?'
# note that we use `"$@"' to let each command-line parameter expand to a
# separate word. the quotes around `$@' are essential!
# we need temp as the `eval set --' would nuke the return value of getopt.
#-o表示短选项,两个冒号表示该选项有一个可选参数,可选参数必须紧贴选项
#如-carg 而不能是-c arg
#--long表示长选项
#"$@"在上面解释过
# -n:出错时的信息
# -- :举一个例子比较好理解:
#我们要创建一个名字为 "-f"的目录你会怎么办?
# mkdir -f #不成功,因为-f会被mkdir当作选项来解析,这时就可以使用
# mkdir -- -f 这样-f就不会被作为选项。
temp=`getopt -o ab:c:: --long a-long,b-long:,c-long:: \
-n 'example.bash' -- "$@"`
if [ $? != 0 ] ; then echo "terminating..." 2 ; exit 1 ; fi
# note the quotes around `$temp': they are essential!
#set 会重新排列参数的顺序,也就是改变$1,$2...$n的值,这些值在getopt中重新排列过了
eval set -- "$temp"
#经过getopt的处理,下面处理具体选项。
while true ; do
case "$1" in
-a|--a-long) echo "option a" ; shift ;;
-b|--b-long) echo "option b, argument \`$2'" ; shift 2 ;;
-c|--c-long)
# c has an optional argument. as we are in quoted mode,
# an empty parameter will be generated if its optional
# argument is not found.
case "$2" in
"") echo "option c, no argument"; shift 2 ;;
*) echo "option c, argument \`$2'" ; shift 2 ;;
esac ;;
--) shift ; break ;;
*) echo "internal error!" ; exit 1 ;;
esac
done
echo "remaining arguments:"
for arg do
echo '-- '"\`$arg'" ;
done
运行命令:
复制代码代码如下:
./getopt.sh --b-long abc -a -c33 remain
option b, argument `abc'
option a
option c, argument `33'
remaining arguments:
-- `remain'
以上提供参考学习,谢谢!
2、请问linux命令上的选项和参数两者有什么区别
我个人理解,命令操作的对象叫参数,选项是对操作的过程做个修饰。就像我们说,杀鸡,杀是命令,鸡就是参数,而选项是个修饰,比如凶狠的杀,还是温柔的杀。
比如删除文件 rm file,rm是命令,file是参数,我们没给选项,可以加个选项,执行rm -f file,这里-f就是选项,代表force,强制删除,就是修饰这个删除动作的过程的
3、我在做Linux的考试题目大家帮我答,感激不敬,3个名词解释题 指令取代:PAM(可插拔认证模块):位置参数:
指令取代:是指alias的命令别名功能吗,以新名称代替旧名称
#alias 命令名 新命令名
PAM:PAM 是一套应用程序编程接口 (Application Programming Interface, API),他提供了一连串的验证机刢,叧要使用者将验证阶段的需求告知 PAM 后, PAM 就能够回报使用者验证的结果 (成功或失败)。
位置参数:输入shell脚本作为命令时,后面可接的参数,用空格分隔。此时shell脚本名就是$0,第一个参数就是$1,第二个是$2........这些就是位置参数,并可作为变量可以在脚本中使用
4、编写linux shell一个脚本,要求如果第一个位置参数是合法目录,那么就把后面给出的各个位置参数所对应的文
在上网浏览了恶意网页后,经常会遇到注册表被禁用的事情。注册表被加锁,其主要原理就是修改注册表。在注册表HKEY_CURRENT_USER\Software\Microsoft\Windows\
CurrentVerssion\Policies\System分支下,新建DWORD值“Disableregistrytools”,并设键值为“1”。这样,当有人运行注册表编辑器时就会出现“注册编辑已被管理员所禁止”的对话框(如图1),这样就可以达到限制别人使用注册表编辑器的目的。给注册表解锁的方法有很多,编辑REG文件导入注册表是最常用的。本文要介绍的是与众不同的七招,在此与您分享。
用Word的宏来解锁
Word也可以给注册表解锁?没错!我们利用的是微软在Word中提供的“宏”,没想到吧?具体方法是:运行Word,然后编写如下面所示的这个“Unlock”宏,即可给注册表解锁:
Sub Unlock()
Dim RegPath As String
RegPath = “HKEY_CURRENT_USER\Software
\Microsoft\Windows\CurrentVersion\Policies\System”
System.PrivateProfileString(FileName:=“”,Section:=RegPath,Key:=“Disableregistrytools”)=“OK!”
End Sub
其实,这个方法一点都不神秘,只是利用了注册表的一个特性,即在同一注册表项下,不能有相同名字的字符串值和DWORD值,如果先前有一个DWORD值存在,则后建立的同名的字符串值会将其覆盖,这也就间接的删除了原值。在本例中就是DWORD值Disableregistrytools被同名的字符串值所覆盖删除。
修改Regedit.exe文件
修改Regedit.exe文件也可以给注册表解锁,前提条件是手头上要有十六进制文件编辑软件如UltraEdit或WinHex等。我们以UltraEdit为例,用Ultraedit打开注册表编辑器Regedit.exe。点击“搜索”菜单下的“查找”,在弹出的对话框中的“查找ASCII字符”前面打上“√”,在“查找什么”栏中输入:Disableregistrytools(如图2),点击“确定”开始查找。会找到仅有的一处结果,改成别的字符就可以了。不过长度一定要一样(20个英文字母),这样就可以解除对注册表编辑器的禁用。
使注册表编辑器无法被禁用
给注册表编辑器Regedit.exe做个小手术,使之对注册表禁用功能具有“免疫力”,可以打造一个锁不住的注册表编辑器。这对防范恶意网页对注册表的禁用非常有好处。用十六进制文件编辑器Ultraedit打开Regedit.exe,查找74 1B 6A 10 A1 00,找到后,把74改为EB即可。现在,你就有了一个锁不住的注册表编辑器了。下次既使注册表被禁用也不用害怕了,只管运行之,保管恶意网页的修改无效。
用INF文件解锁
大家一定看到过在Windows中有一种后缀为INF的驱动安装文件,它实际上是一种脚本语言,通过解释执行。它包含了设备驱动程序的所有安装信息,其中也有涉及修改注册表的相关信息语句,所以我们也可以利用INF文件对注册表解锁。
INF文件是由各个小节(Section) 组成。小节的名字从中括号中起,且在此文件中必须是惟一的。小节的名字是它的入口点。后面是小节内容,形式上是“键名称=键值”。在文件中可以添加注释,由分号完成,分号后的内容不被解释执行。让我们开始行动,用记事本编辑如下内容的文件:
[Version]
Signature=“$CHICAGO$”
[DefaultInstall]
DelReg=del
[del]
HKCU,Software\Microsoft\Windows\CurrentVersion\Policies\
System,Disableregistrytools,
1,00,00,00,00
将上面的内容存为del.inf,使用时用右键点击它,在弹出菜单中选择“安装”即可给注册表解锁(如图3)。
用JScript解锁
用记事本编辑如下内容的文件,保存为以.js为后缀名的任意文件,使用时双击就可以了。
VAR WSHShell=WSCRIPT.CREA-TOBJEt(“WSCRIPT.SHELL”);
WSHShell.Popup(“为你解锁注册表”);
WSHShell.RegWrite(“HKCU\\Software\\Microsoft\\
Windows\\CurrentVersion\\Policies\\
system\\DisableRegistryTools”, 0,“reg_dword”);
大家可以看出用JS对键值进行操作时要用两斜杠“\\”,并且要用“;”表示结束。一般只要能注意这两点,就没有问题了。
用VBScript解锁
用VBScript对注册表进行解锁?没错!很容易又很简单的一个方法,用记事本编辑如下内容:
DIM WSH
SET WSH=WSCRIPT.CreateObject(“WSCRIPT.SHELL”)
WSH.POPUP(“为你解锁注册表!”)
WSH.Regwrite“HKCU\Software\Microsoft\Windows\
CurrentVersion\Policies\System\DisableRegistryTools”,0,“REG_DWORD”
WSH.POPUP(“注册表解锁成功!”)
将以上内容保存为以.vbs为扩展名的任意文件,使用时双击即可。
5、linux中%什么意思
在linux系统中在命令行中Bash中特有的字符串替换方式。
其中%是linux中shell中一般代表变量,其中linux系统中有系统变量和自定义变量。
其中有些事系统自带的变量如使用env命令显示所有的环境变量,还有一些是自己编写的变量,具体含义需要提前赋值。
其中系统变量如系统提供的参数称为位置参数。参数的值可以用$N得到,N是一个数字,如果为1,即$1。如果是%表示则为%1.
我举一个列子帮助理解:
假设一个变量:
x=abcdabcd
那么:
echo ${x/a/b} # 只替换第一个a为b,结果:
bbcdabcd
%echo ${x//a/b} # 将所有a替换为b,结果:
bbcdbbcd
其中不可以使用正则表达式, 只能用 * ? 等通配符。
6、linux中的shell变量的种类及各种类的用处是什么?
2.1.1 本地变量
定义:是在用户现在的shell生命期的脚本中使用;
例:[redhat@server redhat]$name="Red Hat Linux" #把变量设置为Red Hat Linux
[redhat@server redhat]$echo ${name} or #显示变量内容
=[redhat@server redhat]$echo $name #等同上面的语意
Red Hat Linux #显示其设定内容,
[redhat@server redhat]$set | grep "name" #查看刚才所设定的内容,或不加'grep "name"'查看用户自己所有的本地变量,
[redhat@server redhat]$readonly name #把name这个变量设置为只读变量,不允许再次设置,这可参考变量定义;-_-!
[redhat@server redhat]$name="He SenLin" #重新赋值
bash:name:readonly variable #只读文件系统
[redhat@server redhat]$readonly #查看系统存在的只读文件
附:重新登录一下系统,再次用
[redhat@server redhat]$echo ${name}
#本地变量就不存在了,
说明本地变量只能存活在用户shell的生命周期中,重登录就不在了,
2.1.2 环境变量
定义:环境变量用于所有用户进程通称为子进程,包括编辑器,脚本和应用,登录进程为父进程,shell中执行的用户进程均为子进程,不像本地变量只用于现在的shell.
存在目录在所有用户的主目录下即/home/.bash_profile或
如何设置环境变量?第一种方法就是编辑上面的二个文件,还可以用"export"进行设定或更改;这可不像本地变量只需 name="Red Hat Linux"那样简单,但却可以把本地变量更改为环境变量;只须在本地变量结束后,输入:export 变量名;例,我们把name由本地变量修改为环境变量,我们可以这样做;
[root@server root]#name="Red Hat Linux" #本地变量
[root@server root]#export name #变量name由本地升为环境
当然也可以用下面这种方法;
[root@server root]#export name="Red Hat Linux" #直接定义name为环境变量;
定义后,可通过env进行查看,不知道上面的本地环境变量由哪个命令进行查看你记住了没有?,演示一下查看现在定义的环境变量;
[root@server root]#env | grep "name"
Red Hat Linux
同样不加后面grep "name",这个参数也是查看所有的环境变量;更同样的是我们也可以运行readonly这个参数给name以只读属性;
Tips:环境变量就是全部包含在本地变量中因为它即可运行中父进程中也可运行于子进程中,注意一点,本地变量不能运行在全部进程中,只有环境变量可以,再不懂就联想一下人与自然吧;-_-!还是不会?用绝招:
[root@server root]#you=myfriend #设置本地变量name为myfriend
[root@server root]#echo ${you} #查看一下是否成功
myfriend #成功
[root@server root]#sh #更换shell环境等同重登录,这相当一个
sh-2.05b#echo $you #用户子进程
#没显示,说明不存在,真的不存在?
sh-2.05b#exit #返回bash环境
[root@server root]#echo $you #再次查看;
myfriend #又出来了,怎么回事?
[root@server root]#export you #把变量you设为环境变量;
[root@server root]#sh #再试一次;
sh-2.05b#echo $you
myfriend #ok,you see?
再不懂,,你就把我杀了吧,,什么,你不知道我住在哪?汗-_-!
再补充一点,就是在sh进程中设置环境变量是可以写回bash环境中,因为bash是父进程,只有老的才有小的,小的怎么才能有老的哩?长大了就有老的喽,哦,也对!..乱语
2.1.3 变量替换
定义:用变量的值替换它的名字.
查看方式:echo 通用本地,环境...
可以用echo显示可以单个变量的取值;
[root@server root]#str="this is example" #设置本地变量
[root@server root]#echo "can you see `echo $str`" #显示
cat you see this is example #替换就到这了,不明白明再来
变量替换续
除了上面的这个方式以外还有五种哦;别急,一个一个来;-_-!先说好,偶不是皮条
格式 定义
${variable name} 显示实际值到variable name 1
${variable name :+value} 如果设置了variable name,就把value显示,
未设置则为空; 2
${variable name:-value} 如果设置了variable name,就显示它,未设置就显示
value仅显不存本地中; 3
${variable name:?value} 未设置提示用户错误信息value; 4
${variable name:=value} 如未设置就把value设置并显示写入本地中, 5
变量清除:
unset 变量name
[root@server root]#echo $name #变量 name是否存在?
Red Hat Linux #存在
[root@server root]#unset name #清除name变量
[root@server root]#echo $name #是否成功
#成功
注意:如果用readonly限制了只读属性就会失败,还有怎么从环境变量中去掉那个变量呢?还记的用哪个设定环境变量的吗?对.export,只须在它后面加"-n"参数即可
2.1.4 位置变量
定义:位置变量表示$0,$1,$2,....$9
$0 $1 $2 $3 $4
脚本名 A B C D
向脚本中使用位置参数;
向系统命令传递参数;
例:./test在程序中进行替换
[root@server root]#vi /test #创建并编辑/test文件
#!/bin/bash
#test
echo "这是脚本的第一个名称: $0"
echo "这是脚本的第二个位置参数: $1"
echo "这是脚本的第三个位置参数: $2"
echo "这是脚本的第四个位置参数: $3"
echo "这是脚本的第五个位置参数: $4"
[root@server root]#chmod u+x ./test #加执行权限;
[root@server root]#./test A B C #加参数证验
echo "这是脚本的第一个名称: ./test
echo "这是脚本的第二个位置参数: A
echo "这是脚本的第三个位置参数: B
echo "这是脚本的第四个位置参数: C
echo "这是脚本的第五个位置参数:
向系统命令中传递位置参数
[root@server root]#vi test1.sh #新建一个脚本文件
#!/bin/bash
#name:test1.sh
#to call: test1.sh 755 #使用方式
find ~ -perm $1 -print
$2 #系统命令
[root@server root]#chmod u+c test1.sh
[root@server root]#./test1.sh 755 date #位置一为755,2位date
/dev/ip
/dev/iput
.
.
.
Fri May 13 2:31:54 CST 2006
2.1.5 标准变量:
bash默认建立一些环境变量就是标准变量,可以通俗的说就是不是你加的而是装好机子带的那些环境变量, 可在/etc/profile中进行定义,
命令 意义
HOME 用户主目录
IFS 默认分隔符
MAIL 邮箱地址
MAILCHECK 邮箱检查间隔
PWD 用户当前工作目录
LOGNAME 当前用户登录名
2.1.6 特殊变量
命令 意义
$# 传递到脚本的参数列表
$? 前个命令执行情况,0成功,其它值失败
$$ 脚本运行的当前进程号
$! 运行脚本最后一个命令
$* 显示脚本全部参数
2.1.7 影响变量的命令
declare 设置或显示变量
-f 只显示函数名
-r 创建只读变量
-x 创建转出变量
-i 创建整数变量
使用"+"代替"-",可以颠倒选项的意思,-r除外,
export 用于传递给子shell的变量
-- 表明选项结束,所有后续参数都是实参,
-f 表明在"名-值"对中的名字是函数名,
-n 把全局变量转换成局部变量,换句话就是不再传给shell
-p 显示全局变量列表,
shift
用于移动位置变量,调整位置变量,使$3的值赋给$2.$2的值赋予$1.
[root@server root]#vi /test
#!/bin/bash
#test
echo "这是脚本的第一个名称: $0"
echo "这是脚本的第二个位置参数: $1"
echo "这是脚本的第三个位置参数: $2"
echo "这是脚本的第四个位置参数: $3"
echo "这是脚本的第五个位置参数: $4"
shift
echo "这是脚本的第二个位置参数: $1"
echo "这是脚本的第三个位置参数: $2"
[root@server root]#chmod u+x ./test
[root@server root]#./test A B C
echo "这是脚本的第一个名称: ./test
echo "这是脚本的第二个位置参数: A
echo "这是脚本的第三个位置参数: B
echo "这是脚本的第四个位置参数: C
echo "这是脚本的第五个位置参数: $4"
shift #显示的时候并没有,加在此只会明了
echo "这是脚本的第二个位置参数: B
echo "这是脚本的第三个位置参数: C
给shfit加一个数试一下:
[root@server root]#vi ./test
#!/bin/bash
#test
echo "这是脚本的第一个名称: $0"
echo "这是脚本的第二个位置参数: $1"
echo "这是脚本的第三个位置参数: $2"
echo "这是脚本的第四个位置参数: $3"
echo "这是脚本的第五个位置参数: $4"
shift 2
echo "这是脚本的第二个位置参数: $1"
echo "这是脚本的第三个位置参数: $2"
[root@server root]#./test A B C D
echo "这是脚本的第一个名称: ./test
echo "这是脚本的第二个位置参数: A
echo "这是脚本的第三个位置参数: B
echo "这是脚本的第四个位置参数: C
echo "这是脚本的第五个位置参数: D
shift 2 #显示的时候并没有,加在此只会明了
echo "这是脚本的第二个位置参数: C
echo "这是脚本的第三个位置参数: D
第二节 引号
2.1 引号的必要性
2.2 双引号有什么作用
2.3 单引号的作用
2.4 反引号的作用
2.5 反斜杠的作用
关于位置参数有哪些linux和位置参数和形状参数的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。