bash的基础特性:
    globbing:文件名通配(整体文件名匹配,而非部分)
        匹配模式:元字符
            *:匹配任意长度的任意字符
                例:pa* 以pa开头的都符合
                    *pa* 包含pa的都符合
                    *pa    以pa结尾的都符合
                    *p*a* 里边有p,有a不在一起的都符合

?:匹配任意单个字符
                pa?
                    pa 不符合
                    paa 符合
                    passwd 不符合
                ??pa
                p?a
                p?a?

[]:匹配指定范围内的任意单个字符
                有几种特殊格式:
                    [a-z],[A-Z] 注意:在这儿不区分大小写的
                    [0-9] 表示任意单个数字
                    [a-z0-9] 表示数字,或英文字母都可以
                    [abcxyz] 在前边字母中任意一个字母

[[:upper:]]    表示所有大写字母
                    [[:lower:]] 表示所有小写字母
                    [[:alpha:]] 表示所有字母
                    [[:digit:]] 表示所有数字
                    [[:alnum:]]    表示所有的字母和数字
                    [[:space:]] 表示所有空白字符
                    [[:punct:]] 表示所有标点符号

例:表示pa后边有两位数字 pa[0-9][0-9]
                            表示200-299 2[0-9][0-9]

[^]:匹配指定范围外的任意单个字符
                [^[:upper:]] 非大写字符之外的单个字符
                [^0-9] 非数字之外的单个字符
                [^[:alnum:]] 非所有字母和数字外的单个字符

IO重定向及管道
    程序:指令+数据
        程序:必须要有IO,每个程序必定有输入输出的地方

可用于输入的设备:文件
            例如:键盘设备、文件系统上的常规文件、网卡等
        可用于输出的设备:文件
            显示器、文件系统上的常规文件、网卡等

程序的数据流有三种:
            输入的数据流:<--标准输入(stdin),键盘
            输出的数据流:-->标准输出(stdout),显示器
            错误输出流:  -->错误输出(stderr),显示器

生成的文件有与之对应的fd:file descriptor,文件描述符
            标准输入:0
            标准输出:1
            错误输出:2

IO重定向:
        输出重写向:>
            特性:覆盖输出
        输出重定向:>>
            特性:追加输出

# set -C
            禁止覆盖输出重写向已存在的文件
            此时可使用强制覆盖输出:>|
        # set +C
            关闭"set -C"的功能
          # cat /etc/issue > /tmp/issue.out
        可以看到上边不让覆盖已存在的文件
          # cat /etc/issue >| /tmp/issue.out
        如果想要强行覆盖已存在的文件,可以用“>|”

错误输出流重定向:2>,2>>
        合并正常输出流和错误输出流:
            第一种:&>
                    &>>
            第二种:COMMAND > /PATH/to/somefile 2>&1
                    COMMAND >> /PATH/to/somefile 2>&1

特殊设备: /dev/null
                放到这个文件里边的数据都会被丢弃,如果我们不需要数据流的时候可以放到这个里边
                比如有时候我们只需要命令的状态结果,而非数据时就可以用到这个特殊设备

输入重定向:<
            tr命令:
                tr 命令用于转换或删除文件中的字符。
                tr 指令从标准输入设备读取数据,经过字符串转译后,将结果输出到标准输出设备。
                tr [OPTION]... SET1 [SET2]
                    把输入的数据当中的字符,凡是在SET1定义范围内出现的,通通对位转换为SET2出现的字符

参数说明:
                     -c, --complement:反选设定字符。也就是符合 SET1 的部份不做处理,不符合的剩余部份才进行转换
                    -d, --delete:删除指令字符
                    -s, --squeeze-repeats:缩减连续重复的字符成指定的单个字符
                     -t, --truncate-set1:削减 SET1 指定范围,使之与 SET2 设定长度相等

用法1:
                    tr SET1 SET2 < /PATH/form/somefile
                用法2:
                    tr -d SET1 < /PATH/form/somefile
                注意:不修改原文件

Here Document:<<        
                cat << EOF
                cat > /PATH/to/somefile << EOF

管道:|
        连接程序,实现将前一个命令的输出直接定向后一个程序当作输入
        COMMAND1 | COMMAND2 | COMMAND3 ……

tee命令:
            把前一个命令的结果既保存一份到文件中,又把结果输出到显示器中
            COMMAND | tee /PATH/to/somefile

练习1:把/etc/passwd文件的前6行的小写输出为大写
        # head -6 /etc/passwd | tr 'a-z' 'A-Z'

Linux用户组管理及用户权限1的更多相关文章

  1. Linux用户组管理及用户权限2

    用户.组和权限管理    Multi-tasks,Multi-Users,多任务,多用户的计算机    每个使用者:        用户标识.密码:            Authentication ...

  2. Linux用户组管理及用户权限4

    权限管理:    ls -l        rwxrwxrwx:            左三位:定义user(owner)的权限            中三位:定义group的权限           ...

  3. Linux用户组管理及用户权限3

    用户.组管理命令 安全上下文:        进程以其发起者的身份运行:            进程对文件的访问权限,取决于发此进程的用户的权限 系统用户:为了能够让那些后台进程或服务类进程以非管理员 ...

  4. linux用户管理,linux用户口令管理,linux用户组管理,linux用户权限管理详解

    linux用户管理 http://www.qq210.com/shoutu/android 用户账号的添加(新加用户需添加用户口令) :增加用户账号就是在/etc/passwd文件中为新用户增加一条记 ...

  5. linux 用户管理,用户权限管理,用户组管理

    linux 用户管理,用户权限管理,用户组管理 一:ls -l 命令 解释 第个d表示是目录,如果是文件是-,如果是连接是l 第2到4个 rwx 表示创建者的操作权限 r 读,w 写,x 执行 第5到 ...

  6. Linux运维六:用户管理及用户权限设置

    Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统.用户的账号一方面可以帮助系统管理员对使用系统的用户进行 ...

  7. linux和windows互传文件、用户配置文件和密码配置文件、用户组管理、用户管理...

    linux和windows互传文件 第一种:在linux主机上下载lrzsz软件包 1.yum install lrzsz 2.通过rz命令上传window的文件到linux主机上 用过sz 文件名下 ...

  8. Linux常用命令之用户权限管理chmod、chown、chgrp、umask命令讲解

    这节课我们重点来学习权限管理命令,说到权限大家可能第一时间能想到的就是读.写.执行 rwx 三种权限,在正式讲解权限命令之前,先简单的介绍一下rwx权限对于文件和目录的不同含义. 权限字符 权限 对文 ...

  9. Linux系列教程(十五)——Linux用户和用户组管理之用户管理命令

    上篇博客我们介绍了用户管理的相关配置文件,包括用户信息文件/etc/passwd,用户密码文件/etc/shadow:然后介绍了用户组信息文件/etc/group,用户组密码文件/etc/gshado ...

随机推荐

  1. 安装最新docker-ce失败解决

    报错 下载 检查本地是否已经安装 rpm -qa |grep containerd.io 如果有低版本的,卸载即可. 安装新版的containerd.io软件包 wget https://downlo ...

  2. python3速查参考- python基础 2 -> if语句应用 + while循环应用

    if语句应用之——求最大值 """ 求三个数字中的最大值,并打印出来 """ a = int(input("a:")) ...

  3. 算法题--Z字形变换

    题目描述 将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: L C I ...

  4. 阿里P8架构师谈:Restful、SOAP、RPC、SOA、微服务之间的区别(转载)

    转载来源:https://youzhixueyuan.com/the-difference-between-restful-soap-rpc-soa-and-micro-service.html 内容 ...

  5. BasePage基础页面的封装

    Paget Object设计模式,不多说,但在接触了poium测试库后,个人感觉BasePage都是多余的..但在次还是做个记录 class Page(): def __init__(self, dr ...

  6. 论文阅读 | Robust Neural Machine Translation with Doubly Adversarial Inputs

    (1)用对抗性的源实例攻击翻译模型; (2)使用对抗性目标输入来保护翻译模型,提高其对对抗性源输入的鲁棒性. 生成对抗输入:基于梯度 (平均损失)  ->  AdvGen 我们的工作处理由白盒N ...

  7. gitlab本地部署方法(ubuntu16.04+gitlab9.5.5)

    Gitlab本地部署方法   1 前期准备 电脑配置:windows7 ,内存8GB以上(因为有4GB左右要分配给虚拟机中的ubuntu) 虚拟机:VMware Linux系统:ubuntu16.04 ...

  8. DRF url控制 解析器 响应器 版本控制 分页(常规分页,偏移分页,cursor游标分页)

    url控制 第二种写法(只要继承了ViewSetMixin) url(r'^pub/$',views.Pub.as_view({'get':'list','post':'create'})), #获取 ...

  9. tensorflow零起点快速入门(3)

    创造并运行数据 创造了-3到3的32条数据,然后通过sess.run获取并显示输出数据. x=tf.linspace(-3.0,3.0,32) print(x) sess=tf.Session() r ...

  10. 浅谈JMX

    JMX在Java编程语言中定义了应用程序以及网络管理和监控的体系结构.设计模式.应用程序接口以及服务.通常使用JMX来监控系统的运行状态或管理系统的某些方面,比如清空缓存.重新加载配置文件等 优点是可 ...