我是靠谱客的博主 含糊大地,最近开发中收集的这篇文章主要介绍c语言将pwd结果赋给变量,第二天 引用 命令执行顺序 变量,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

目录

引用

命令执行顺序

变量

特殊变量

引用

为防止shell解释一些东西,所以就有了引用,四种符号  " ' `

双引、单引和反引号

使用反斜线实现屏蔽,转义。反斜线引用单个字符时,称它为转义字符

双引号除$ ` 三种符号外,引用所有内容,称为弱引用

[root@localhost script]# echo "$TERM pwd "

xterm pwd

[root@localhost script]# echo "`ls` pwd "

passwd

user pwd

[root@localhost script]# echo "`ls` pwd "

`ls` pwd

单引号引用所有内容,没有字符拥有特殊含义,称为强引用

反引号

shell试图替代单词hello为系统命令并执行它,因为hello脚本或命令不存在,返回错误信息。

[root@localhost script]# echo `hello`

-bash: hello: command not found

[root@localhost script]# echo `date`

Mon Dec 30 18:08:21 CST 2013

如果使用引用得到的结果不理想,再试另一种,毕竟只有三种引用方式,可以充分尝

试。

反斜线

引用单个字符时,称它为转义字符,

最强引用,可以转义单引号

引用

单引号''

引用一串字符

强引用,单引号强,只有一个

引用

双引号""

保留$ ` 三种符号的特殊含义

弱引用,双引号

弱,有两个

引用

当使用字符时,应总是使用双引号,无论它是单个字符串或是多个单词

反引号``

命令替换

命令替换

命令执行顺序

&&,||,(),{} 四个符号的运用

shell脚本执行命令的时候,有时候会依赖于前一个命令是否执行成功。而&&和||就是用来判断前一个命令执行效果的。

1  &&  与

使用方法:命令1 &&  命令2

这个方式简单明了,命令1如果返回结果为真(即执行返回为0,成功执行)后,命令2才被执行

换句话说,如果命令1执行成功&&那么执行命令2

这里有个命令

[ -f /home/dellogs.sh ] && echo "清除日至脚本存在"

总之,&&符号代表如果第一个命令执行成功才执行第二个命令。

2  ||  或

使用方法:命令1 || 命令2

||命令,如果命令1没有执行成功则执行命令2

如简单例子

cp wopper.txt oop.txt || echo "cp命令执行没有成功"

如果||左边的命令没有执行成功,则屏幕中除显示“cp命令执行没有成功”

下面给出一个更为实用的例子,

awk ‘{print$1,$5}’ acc.qrt >qtr.tmp || echo "sorry the payroll(薪水) extraction(抽取) did'not work" | mail root

3 除了使用&&和||这两方法外,还可以用(),{}这两个符号把命令连接起来

()和{}存在的目的只是为了,能一个shell或子shell中执行一组命令

使用方法(命令1;命令2;命令3;...)和{命令1;命令2;命令3;...}

这种情况比较少遇到,一般要和&&,||两个命令一起使用。

例如

comet monthent || (echo “Hello,quess what! comet did not work”| mail root;exit)

变量

变量的赋值有五种:使用read命令,直接赋值,使用命令行参数,使用命令行的输出结果,从文件读取。

1 先说一下从read命令吧:(主要是在需要交互时使用)

Read命令是系统内置命令,语法格式为:

read  变量1   变量2

当Shell脚本执行到read命令时,将暂停脚本的执行并等待键盘的输入,当用户输入完毕并且敲下回车之后,将完成赋值操作,脚本继续执行。

Read指令的规则:

多个数据或变量之间用空格隔开

若变量个数与数据个数相等时,对应取值

若变量个数大于数据个数时,没有输入数据的变量取空值

若变量个数小于数据个数时,将多余的数据赋给最后一个变量(也就是把空格当成字符串处理)

例子:

#!/bin/bash

echo -n “ please enter your name”  //-n 表示用户输入和提示信息在同一行

read name

echo “your name is $name”

#!/bin/bash

echo “Please  enter  your  first name  and last name :”

read first last

echo “your first name is $first”

echo “your last name is $last”

2 第二种赋值方法就是直接给变量赋值(这种赋值方法主要是在不需要交互时,并且参数不需要修改时使用)

例如:name=xiaosu

gender=man

3 第三种赋值方法是使用命令行参数赋值。(这种赋值方法是参数需要经常变化,并且不需要交互时使用)

这种赋值方法,也就是直接在命令后面跟参数,然后系统用$1来引用第一个参数。

4 第四种方法是利用命令的输出结果赋值(这种赋值方法可以直接处理上个命令产生的数据)

在Shell程序中,可以将一个命令的输出结果来当做变量,不过需要在赋值语句中使用反引号

例如currentdir=`pwd`

echo $currentdir

5 最后一种赋值方法是从文件中读入数据

这种方式就适合处理大批量的数据,直接把相应的数据写入文件,然后运行脚本即可。

通常是通过while循环一行行读入数据,即没循环一次,就从文件中读取一行数据,直到读取到文件的结尾。

例如:

#!/bin/bash

ls *.sh >execfile

while read LINE

do

chmod a+x $LINE

done

这个脚本使用了while..do..done 结构,最后一行表示从文件execfile读取数据。while read LINE表示 每次循环读入一行数据并赋值给变量LINE。

6 变量的输出

最简单的方法就是使用echo

如果想输出格式化的字符串,就需要使用printf,用法和C语言类似

printf 命令的格式说明符

”    输出双引号

\    输出反斜杠

a    响铃

n    换行

r    回车

特殊变量

# vi variable

#!/bin/sh

echo "number:$#"

echo "scname:$0"

echo "first:$1"

echo "second:$2"

echo "argume:$@"

echo "show parm list:$*"

echo "show process id:$$"

echo "show precomm stat:$?"

# chmod +x variable

# ./variable aa bb

number:2

scname:./variable

first:aa

second:bb

argume:aa bb

show parm list:aa bb

show process id:24544

show precomm stat:0

通过显示结果可以看到:

$# 是传给脚本的参数个数

$0 是脚本本身的名字

$1 是传递给该shell脚本的第一个参数

$2 是传递给该shell脚本的第二个参数

$@ 是传给脚本的所有参数的列表

$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过9个

该变量包含了所有输入的命令行参数值。如果您运行showrpm openssh.rpm w3m.rpm webgrep.rpm

此时 $* 包含了 3 个字符串,即openssh.rpm, w3m.rpm and webgrep.rpm.

$$ 是脚本运行的当前进程ID号

$? 是显示最后命令的退出状态,0表示没有错误,其他表示有错误

最后

以上就是含糊大地为你收集整理的c语言将pwd结果赋给变量,第二天 引用 命令执行顺序 变量的全部内容,希望文章能够帮你解决c语言将pwd结果赋给变量,第二天 引用 命令执行顺序 变量所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部