• linux文件查看和文件查找


    一、例题

    1. 文件查看

    复制/etc/passwd到/opt目录下。

    查看/opt/passwd文件的第6行

    2.文件查找

    在当前目录及子目录中,查找大写字母开头的txt文件

    在/etc及其子目录中,查找host开头的文件

    在$HOME目录及其子目录中,查找所有文件

    在当前目录及子目录中,查找不是out开头的txt文件

    忽略文件名大小写查找a.txt

    在当前目录除aa之外的子目录内搜索 txt文件

    在当前目录及子目录下,查找符号链接文件

    查找2天内被更改过的文件

    查找2天前被更改过的文件

    查找超过1M的文件

    3.查找文件 /usr/share/rhel.xml 中包含字符串 re 的所有行。将所有这些行的副本按原始顺序放在文件/root/files 中。

    查找:

    将搜索到的含有re的行输出重定向到/root/files中:

    二、命令所对应的作用

    1.复制文件或目录---cp命令

    命令格式:cp  [选项]  源文件  目标文件

    选项:

    选项功能
    -a通常在拷贝目录时使用。保留链接、文件属性,并且递归拷贝目录
    -d拷贝时保留链接
    -f覆盖已经存在的目标文件时不提示
    -i在覆盖目标文件前将给出提示要求用户确认。回答y时目标文件将被覆盖,交互式拷贝。
    -p除复制文件内容还将把其自改时间和访问权限也复制到新文件中。
    -r给出源文件是一目录文件,此时将递归复制该目录下所有子目录和文件。此时目标文件必须是一个目录名。
    -l不做拷贝,只是链接文件

     2.cat---查看文本文件的内容

    命令格式:cat  [选项]  文件名列表

    常用选项:

    -n---对输出内容的所有行标注行号 
    -b---对输出内容的非空行标注行号

    3.find---对文件名称,大小,类型,权限,日期等进行搜索。

    命令格式:find 搜索路径 [选项] 搜索内容  -- 如果不提供搜索路径,则在当前目录查找 

    (1)按照文件名搜索

    -name: 按照文件名搜索
    -iname: 按照文件名搜索,不区分文件名大小写
    -inum: 按照 inode 号搜索

    (2)按照文件大小搜索

    -size [+|-]大小: 按照指定大小搜索文件

    (3)按照指定修改时间搜索文件

    -atime [+|-]时间: 按照文件访问时间搜索
    -mtime [+|-]时间: 按照文件数据修改时间搜索
    -ctime [+|-]时间: 按照文件状态修改时间搜索

    (4)按照文件类型查找

    -type d: 查找目录
    -type f: 查找普通文件
    -type l: 查找软链接文件

    (5)逻辑运算符

    -a: and 逻辑与
    -o: or 逻辑或
    -not: not 逻辑非

    (6)对应参数及作用

    参数

    作用

    -name匹配名称
    -perm匹配权限(mode为完全匹配)
    -user匹配所有者
    -group匹配所有者
    -mtime -n +n匹配修改内容的时间(-n指 n 天内,+n指 n 天以前)
    -atime -n +n匹配访问文件的时间(-n指 n 天以内,+n指 n 天以前)
    -ctime -n +n匹配修改文件权限的时间(-n指 n 天内,+n指 n 天以前)
    -nouser匹配无所有者文件
    -nogroup匹配无所有组的文件
    -newer f1 !f2匹配比文件f1新但比f2旧的文件
    -type b/d/c/p/l/f匹配文件类型(后面的字母参数依次代表块设备、目录、字符设备、管道、链接文件、文本文件)
    -size匹配文件的大小(+50k为查找超过50k的文件,而-50k为查找小于50k的文件)
    -prune忽略某个目录
    -exec……{} \;后面可跟用于进一步处理搜索结果的命令

    (7)示例:

    <1> 查找当前文件路径下大于50k,小于5M的文件

    [root@server ~]# find -size +50k -size -5M -exec ls -lh {} \;

    <2> 查找7天前删除(日志文件)

    [root@server ~]# find ./ name “*.log” -mtime +6

    4.grep---用于按行提取文本内容

    命令格式:grep  [参数]  文件名称

    选项:

    参数作用
    -b将可执行文件(binary)当做文本文件(test)来搜索
    -c仅显示找到的行数
    -i忽略大小写
    -n显示行号
    -v反向选择---仅列出没有“关键词”的行

    示例:

    <1> 查找文件/etc/passwd中以root开头的行  ^root ---正则表达式

    [root@server ~]# grep "^root" /etc/passwd

    <2> 查找文件/etc/passwd中/bin/bash结尾的行 

    [root@server ~]# grep "/bin/bash$" /etc/passwd

    <3> 统计文件中含有root的行,不区分大小写

    [root@server ~]# grep -i "root" /etc/passwd

    <4>  过滤配置文件中的注释和空行

    [root@server ~]# grep -E -v "#|^$" /etc/ssh/sshd_config

  • 相关阅读:
    每天五分钟计算机视觉:池化层的反向传播
    【ElasticSearch】HTTP调用API
    ​​​​​​​Python---练习:打印直角三角形(利用wihle循环嵌套)
    455. 分发饼干
    华三交换机的软件版本升级操作
    【计算机网络】传输层(一)—— 传输层概述
    pushgateway安装及Prometheus配置
    【阅读笔记】《深度学习》第二章:线性代数
    神经网络原理及代码实现
    软件测试 - Linux的远程连接
  • 原文地址:https://blog.csdn.net/weixin_62443409/article/details/127688672