《Linux超酷脚本-Finding Programs in the PATH》

简介:
Linux超酷脚本-Finding Programs in the PATH

 
作用:
验证一个指定的程序能否在当前系统里找到,这里可以是一个绝对路径的程序,或是一个相对路径的程序.

 
源程序如下:

 
#!/bin/bash

 

 
in_path()
{
        local cmd="$1"; local path="$2"; local retval=1
        local oldIFS="${IFS}"; local IFS=":"
        for directory in $path
        do
                if [ -x $directory/$cmd ];then
                        retval=0
                fi
        done
        IFS=$oldIFS
        return $retval
}

 

 
checkForCmdPath()
{

 
        local var=$1
        if [ "${var%${var#?}}" = "/" ];then
                if [ ! -x "${var}" ];then
                        return 1
                fi
        elif ! in_path "${var}" "${PATH}";then
                return 2
        fi
}

 

 
if [ $# -ne 1 ];then
        echo "Usage: $0 command" >&2 ;exit 1
fi

 
checkForCmdPath "$1"

 
case $? in
        0) echo "$1 found in PATH"                      ;;
        1) echo "$1 not found or not executable"        ;;
        2) echo "$1 not found in PATH"                  ;;
esac

 
exit 0

 
分析:

 
1)$#用于统计传递参数的个数,如果我们在程序后面加了三个参数,这里的$#将是3,如果没有指定参数,这里的$#将是0.
2)关于函数的定义,我们有两种定义函数的方法,如下:
checkForCmdPath()
{
}
另一种方法:
function checkForCmdPath
{
}
两种函数的性质完全一样,但是如果采用第二种方法,大括号要和函数名有一个空格或回车键做分隔符,否则function关键字会把大括号和函数名连在一起当做函数名,像下面的定义是错误的:
function checkForCmdPath{
}

 
3)${var%${var#?}},这是一个截取字符串的操作,${var#?}取出$var变量第2个字符到最后一个字符,再通过${var%$strings}取出$var变量的第一个字符.
首先我们分析${var#?},从左向右截取第一个string后的字符串
如下:
var="abcdefabcdef"
echo ${var#?}
bcdefabcdef
这里的?号是指任意一个字符.
如果是$(var#abc),截取后的结果是defabcdef
如果是${var#def},截取后的结果是abcdefabcdef
这说明一定要从左第一个字符进行完全配匹,如不能完全配匹则返回原字符串.

 
再下来分析$(var%strings),它表示从右向左截取第一个string后的字符串
如下:
var="abcdefabcdef"
echo ${var%def}
abcdefabc
echo ${var%abc}
abcdefabcdef
上面的例子说明它从右第一个字符进行配匹,如不能完全配匹则返回原字符串.

 
最后我们看几个截取字符串的实例:
echo ${var##*abc} //从左向右截取最后一个string后的字符串
def
echo ${var#*abc}  //从左向右截取第一个string后的字符串 
defabcdef
echo ${var%%cde*} //从右向左截取最后一个string后的字符串
ab
echo ${var%cde*}  //从右向左截取第一个string后的字符串
abcdefab
echo ${var:1:4}   //截取第1个字符到第4个字符,注意这里是从第0个字符算起
bcde
echo ${var:1}     //截取第1个字符到最后一个字符 
bcdefabcdef
echo ${var}|cut -c1,4 //截取第1个字符和第4个字符,注意这里是从第1个字符算起
ad
echo ${var}|cut -c2-8 //截取第2个字符到第8个字符
bcdefab

 

 
4)对于函数的返回值,要说明的是函数会将函数中最后一条语句中的返回值传给它的调用程序.它的值是0-255,如果出现负值或会用补码将负值转为正值,再在末尾加1进行处理,
如果是大于255的值,会用这个值一直减256,直到最后一个值不足256为止,例如return 800,将得到值将是32,也就是800-256-256-256=32

 
5)对于本例中,我们用IFS来处理路径的问题,IFS变量用于定义分隔符,默认的IFS是$' \t\n',也就是空格或者tab,或者回车.

 
我们用下面的例子来说明IFS的用途,
for record in `cat /etc/passwd`
do
       echo $record
done
输出的结果可能是这样:
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP
User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
rpm:x:37:37::/var/lib/rpm:/sbin/nologin
dbus:x:81:81:System
message
bus:/:/sbin/nologin

 
原passwd文件是这样:
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
rpm:x:37:37::/var/lib/rpm:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin

 
这说明默认的IFS同时用空格,TAB,回车来做分隔,gopher:x:13:30:gopher:/var/gopher:/sbin/nologin一行没有空格和TAB,所以用回车来分隔,得到了一条正确的记录,
而ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin一行有空格,所以它用空格来分隔,这样得到了两条记录,我们将IFS改成用回车来分隔即可解决这个问题,如下:

 
oldIFS=$IFS
IFS=$'\n'
for record in `cat /etc/passwd`
do
  echo $record
done
IFS=$oldIFS

 
输出:
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin

来自: http://home.lupaworld.com/home-space-uid-56821-do-blog-id-233541.html

本文转自孤舟夜航之家博客51CTO博客,原文链接http://blog.51cto.com/cysky/588432如需转载请自行联系原作者


cysky

相关文章
|
19天前
|
消息中间件 Java Kafka
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
本文介绍了Kafka集群的搭建过程,涵盖从虚拟机安装到集群测试的详细步骤。首先规划了集群架构,包括三台Kafka Broker节点,并说明了分布式环境下的服务进程配置。接着,通过VMware导入模板机并克隆出三台虚拟机(kafka-broker1、kafka-broker2、kafka-broker3),分别设置IP地址和主机名。随后,依次安装JDK、ZooKeeper和Kafka,并配置相应的环境变量与启动脚本,确保各组件能正常运行。最后,通过编写启停脚本简化集群的操作流程,并对集群进行测试,验证其功能完整性。整个过程强调了自动化脚本的应用,提高了部署效率。
【手把手教你Linux环境下快速搭建Kafka集群】内含脚本分发教程,实现一键部署多个Kafka节点
|
4月前
|
安全 Linux Shell
Linux上执行内存中的脚本和程序
【9月更文挑战第3天】在 Linux 系统中,可以通过多种方式执行内存中的脚本和程序:一是使用 `eval` 命令直接执行内存中的脚本内容;二是利用管道将脚本内容传递给 `bash` 解释器执行;三是将编译好的程序复制到 `/dev/shm` 并执行。这些方法虽便捷,但也需谨慎操作以避免安全风险。
248 6
|
5月前
|
Linux
在Linux中,怎么把脚本添加到系统服务里,即用 service 来调用?
在Linux中,怎么把脚本添加到系统服务里,即用 service 来调用?
|
2月前
|
Ubuntu Linux Shell
Linux 系统中的代码类型或脚本类型内容
在 Linux 系统中,代码类型多样,包括 Shell 脚本、配置文件、网络配置、命令行工具和 Cron 定时任务。这些代码类型广泛应用于系统管理、自动化操作、网络配置和定期任务,掌握它们能显著提高系统管理和开发的效率。
|
2月前
|
运维 监控 Shell
深入理解Linux系统下的Shell脚本编程
【10月更文挑战第24天】本文将深入浅出地介绍Linux系统中Shell脚本的基础知识和实用技巧,帮助读者从零开始学习编写Shell脚本。通过本文的学习,你将能够掌握Shell脚本的基本语法、变量使用、流程控制以及函数定义等核心概念,并学会如何将这些知识应用于实际问题解决中。文章还将展示几个实用的Shell脚本例子,以加深对知识点的理解和应用。无论你是运维人员还是软件开发者,这篇文章都将为你提供强大的Linux自动化工具。
|
3月前
|
运维 Java Linux
【运维基础知识】Linux服务器下手写启停Java程序脚本start.sh stop.sh及详细说明
### 启动Java程序脚本 `start.sh` 此脚本用于启动一个Java程序,设置JVM字符集为GBK,最大堆内存为3000M,并将程序的日志输出到`output.log`文件中,同时在后台运行。 ### 停止Java程序脚本 `stop.sh` 此脚本用于停止指定名称的服务(如`QuoteServer`),通过查找并终止该服务的Java进程,输出操作结果以确认是否成功。
97 1
|
4月前
|
人工智能 监控 Shell
常用的 55 个 Linux Shell 脚本(包括基础案例、文件操作、实用工具、图形化、sed、gawk)
这篇文章提供了55个常用的Linux Shell脚本实例,涵盖基础案例、文件操作、实用工具、图形化界面及sed、gawk的使用。
851 2
|
3月前
|
存储 Shell Linux
【Linux】shell基础,shell脚本
Shell脚本是Linux系统管理和自动化任务的重要工具,掌握其基础及进阶用法能显著提升工作效率。从简单的命令序列到复杂的逻辑控制和功能封装,Shell脚本展现了强大的灵活性和实用性。不断实践和探索,将使您更加熟练地运用Shell脚本解决各种实际问题
45 0
|
4月前
|
Shell Linux 开发工具
linux shell 脚本调试技巧
【9月更文挑战第3天】在Linux中调试shell脚本可采用多种技巧:使用`-x`选项显示每行命令及变量扩展情况;通过`read`或`trap`设置断点;利用`echo`检查变量值,`set`显示所有变量;检查退出状态码 `$?` 进行错误处理;使用`bashdb`等调试工具实现更复杂调试功能。
|
5月前
|
安全 Linux 开发工具
探索Linux操作系统:从命令行到脚本编程
【8月更文挑战第31天】在这篇文章中,我们将一起潜入Linux操作系统的海洋,从最基础的命令行操作开始,逐步深入到编写实用的脚本。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和实用技能。我们将通过实际代码示例,展示如何在日常工作中利用Linux的强大功能来简化任务和提高效率。准备好了吗?让我们一起开启这段旅程,探索Linux的奥秘吧!