1.  判断shell里判断字符串是否包含某个字符

  a.  可以用正则式匹配符号      “=~”

    举例:str="this is a string"
      要想在判断str中是否含有"this"这个字符串,下面的语句是可行的
      [[ $str =~ "this" ]] && echo "\$str contains this"
      [[ $str =~ "that" ]] || echo "\$str does NOT contain this"

2. shell 根据路径字符串截取文件和文件名

比如从路径里取出 文件名或者判断中间某一个文件夹是否存在,不存在就创建新文件夹等。

   a. 使用${ }

  规则是:

  #表示左边,第一个,##表示从左边起最后一个

  %表示右边,第一个,%%表示从右边最后一个

  /和*的使用配合左右,当用到左边时,“ * ”在“/ ”的左边,用到右边时,“ * ”在“ / ”的右边。(“ * ”可以看成是所有,“ * ”在“ / ”左边,表示要把“ / ”左边的全部去掉,加一个“#”去一个,加两个“##”意思是去掉从左边数最后一个的“ / ”的全部左边字符)

  举例:${var#*/}  :去掉从左边起第一个出现的“ / ”和它的左边的内容。

 path=“one/two/three”
new_path=${path#*/}
echo $new_path

  结果: two/three

  举例:${var%%/*}:去掉从右边数最后一个“ / ”及其右边的内容 。

 path=“one/two/three”
new_path=${path%%/*}
3 echo $new_path

  结果:one

  --除了和“ / ”配合使用,也可以和其他特殊字符进行匹配使用--

  比如" . " :       举例 ${var##*.} :表示从去掉左边起最后一个" . "以及它左边的全部内容。即返回从左边数最后一个" . "的右边的内容。

 b. basename和 dirname    【此处参考 https://www.jb51.net/article/103875.htm】

  ${var }其实并不是为了截取文件目录和文件名而存在的,但basename和dirname他们是。

       1)、basename

  该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。

  1)从路径中提出出文件名(带后缀),例子如下:

  

  2)从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:

  

  2、dirname

  该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME

  使用例子如下:

  

  这样就提取出了file.txt文件所在的目录。

  注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:

  

  它提取出了目录dir2所在的目录dir1.

3. shell遍历带有特殊字命名标题的文件和文件夹

linux处理包含空格和特殊字符的文件名可以参考:https://blog.csdn.net/chengxuyuanyonghu/article/details/46820219

  shell处理包含空格的文件名时,echo直接打出来会把空格当做两个文件夹来处理。

  我用的方法是在脚本中替换默认的ifs(internal field separator),脚本运行完之后恢复:

SAVEIFS=$IFS
#更改ifs为换行
IFS=$(echo -en "\n\b") ##执行脚本 IFS=$SAVEIFS

  shell中的IFS解释参考:https://blog.csdn.net/whuslei/article/details/7187639

linux shell 部分问题解决方法的更多相关文章

  1. 关于linux密码忘记问题解决方法

    最近在试装centos,不小心把密码丢了,进不去,查了一下资料,找到了方法,试验成功.存在这里,备用. 1. 在出现grub画面时,用上下键选中你平时启动linux的那一项,然后按e键 2. 再次用上 ...

  2. Linux - Shell脚本调试方法

    Shell脚本调试选项 Shell本身提供一些调试方法选项: -n,读一遍脚本中的命令但不执行,用于检查脚本中的语法错误. -v,一边执行脚本,一边将执行过的脚本命令打印到标准输出. -x,提供跟踪执 ...

  3. linux shell数组赋值方法(常用)

    http://blog.csdn.net/shaobingj126/article/details/7395161 Bash中,数组变量的赋值有两种方法: (1) name = (value1 ... ...

  4. Linux虚拟机小问题解决方法系列

    1)使用虚拟机的过程中,会碰到虚拟机占用的空间越来越大的情况,即使删除了虚拟机里的文件,磁盘空间还是似乎还是没有释放,使用“vmware-vdiskmanager”工具解决.解决方法在这里:参考.合并 ...

  5. Linux Shell自动交互/人机交互的三种方法

    如果你要学习linux,你可能会遇到Linux Shell自动交互问题,这里将介绍Linux Shell自动交互的解决方法,在这里拿出来和大家分享一下. 一.背景 shell脚本在处理自动循环或大的任 ...

  6. 学习Linux shell脚本中连接字符串的方法

    这篇文章主要介绍了Linux shell脚本中连接字符串的方法,如果想要在变量后面添加一个字符,可以用一下方法: 代码如下: $value1=home $value2=${value1}"= ...

  7. linux shell 中数组使用方法介绍

    linux shell在编程方面比windows 批处理强大太多,不管是在循环.运算.已经数据类型方面都是不能比較的. 以下是个人在使用时候,对它在数组方面一些操作进行的总结. 1.数组定义 [che ...

  8. linux shell根据端口返回进程号杀死进程的方法

    linux shell根据端口返回进程号杀死进程的方法<pre>kill `lsof -t -i:9501`</pre>这个就是杀死9501端口的进程号

  9. linux shell获取show slave status方法

    linux shell获取show slave status方法<pre>#!/bin/basharray=($(mysql -u数据库账号 -p数据库密码 -e "show s ...

随机推荐

  1. 五分钟急速搭建wordpress(博主亲测有效)

    第一步:下载WordPress安装包并解压 从此处下载WordPress压缩包并解压缩 http://wordpress.org/download/ 如果你想将WordPress上传至一个远程服务器, ...

  2. document.URL 和 windows.location.href的区别

    1. 从输出结果上,document.URL 和 windows.location.href 没有区别.2. 非要说区别的话,你只可以读取document.URL的值,不能修改它.windows.lo ...

  3. Sharepoint 2013企业内容管理学习笔记终章

    说完了半自动化内容管理&全自动化内容管理,下面我们来说另外一个企业内容管理的东东吧 企业内容记录化 这个企业内容记录化,其实是我起的名字了,在sharepoint里面它叫做声明记录 这个声明记 ...

  4. Movideo SaaS解决方案

    类型: 定制服务 软件包: media solution collateral 联系服务商 产品详情 解决方案 概要 Movideo为媒体客户提供的SaaS解决方案部署在位于全球数据中心的Azure云 ...

  5. jmter安装配置

    一 JMeter 简介 JMeter 它是Apache组织的开放源代码项目,它是现在比较流行的功能和性能测试的工具.JMeter requires a fully compliant JVM 7 or ...

  6. chromedp自动启动为headless模式

    // Command click is a chromedp example demonstrating how to use a selector to // click on an element ...

  7. Linux MySQL单实例源码编译安装5.5.32

    cmake软件 tar -zxvf cmake-2.8.8.tar.gz cd cmake-2.8.8 ./bootstrap make make install cd ../   依赖包 yum i ...

  8. 如果有反向代理的情况下,获取最原始的IP的办法

    HttpContext.Current.Request.ServerVariables["HTTP_X_FORWARDED_HOST"];

  9. 定位webpack文件大小

    之前发现一个神器,记录一下,可以可视化webpack打包的每个js文件大小,这样对我们优化代码是有帮助的,有目标的 https://www.npmjs.com/package/webpack-bund ...

  10. react里面引入图片

    引入图片确实走了很多的坑,开始的认知里,所有静态页面都需要放在public里面能执行,代码是这样的 css .back{ background-image: url('/images/homeBack ...