zoukankan      html  css  js  c++  java
  • linux shell实现对指定目录下的文件依据大小进行排序

    1、find可以实现对指定文件大小的查找

    root@PC1:/home/test2# ls
    b.ped  outcome.map  outcome.ped
    root@PC1:/home/test2# ll -h
    total 1.4G
    -rw-r--r-- 1 root root 1.3G 12月 22 22:30 b.ped
    -rw-r--r-- 1 root root 1.3M 12月 22 22:28 outcome.map
    -rw-r--r-- 1 root root 158M 12月 22 22:29 outcome.ped
    root@PC1:/home/test2# find ./ -type f -size +500M   ## -type f 指定对文件进行查找, -size +500M 指定查找大于500M的
    ./b.ped
    root@PC1:/home/test2# ll -h
    total 1.4G
    -rw-r--r-- 1 root root 1.3G 12月 22 22:30 b.ped
    -rw-r--r-- 1 root root 1.3M 12月 22 22:28 outcome.map
    -rw-r--r-- 1 root root 158M 12月 22 22:29 outcome.ped
    root@PC1:/home/test2# find ./ -type f -size -300M    ## 查找小于300M的文件
    ./outcome.map
    ./outcome.ped

    2、ls -S直接实现对文件大小的排序

    root@PC1:/home/test2# ls
    b.ped  outcome.map  outcome.ped
    root@PC1:/home/test2# ll -h
    total 1.4G
    -rw-r--r-- 1 root root 1.3G 12月 22 22:30 b.ped
    -rw-r--r-- 1 root root 1.3M 12月 22 22:28 outcome.map
    -rw-r--r-- 1 root root 158M 12月 22 22:29 outcome.ped
    root@PC1:/home/test2# ls -S | sed 's/\t/\n/g'
    b.ped
    outcome.ped
    outcome.map
    root@PC1:/home/test2# ls -S | sed 's/\t/\n/g' | xargs du -h   ## ls -S直接实现文件从大到小的排序
    1.3G    b.ped
    158M    outcome.ped
    1.3M    outcome.map
    root@PC1:/home/test2# ls -S | sed 's/\t/\n/g' | xargs du -h | sort
    1.3G    b.ped
    1.3M    outcome.map
    158M    outcome.ped
    root@PC1:/home/test2# ls -S | sed 's/\t/\n/g' | xargs du -h | sort -h   ## 实现从小到大排序
    1.3M    outcome.map
    158M    outcome.ped
    1.3G    b.ped

    3、du命令实现排序

    root@PC1:/home/test2# ls
    b.ped  outcome.map  outcome.ped
    root@PC1:/home/test2# du -ah   ## 列举出每个文件的大小及总大小
    1.3M    ./outcome.map
    1.3G    ./b.ped
    158M    ./outcome.ped
    1.4G    .
    root@PC1:/home/test2# du -ah | sort -h   ## 从小到大排序
    1.3M    ./outcome.map
    158M    ./outcome.ped
    1.3G    ./b.ped
    1.4G    .
    root@PC1:/home/test2# du -ah | sort -h | sed '$d'  ## 从小到大排序并删除最后一行
    1.3M    ./outcome.map
    158M    ./outcome.ped
    1.3G    ./b.ped
    root@PC1:/home/test2# du -ah | sort -rh   ## 从大到小排序
    1.4G    .
    1.3G    ./b.ped
    158M    ./outcome.ped
    1.3M    ./outcome.map
    root@PC1:/home/test2# du -ah | sort -rh | sed 1d  ## 从大到小排序并删除第一行
    1.3G    ./b.ped
    158M    ./outcome.ped
    1.3M    ./outcome.map
  • 相关阅读:
    OpenStack最新版本Folsom架构解析
    三种存储类型比较-文件、块、对象存储
    4椭圆曲线密码学:破坏安全性及与RSA的比较
    3椭圆曲线密码学:ECDH和ECDSA
    2椭圆曲线密码学:有限域和离散对数
    1椭圆曲线密码学:简介
    区块链部署
    PBFT算法流程
    Raft和PBFT算法对比
    【P2P网络中的声誉计算】The EigenTrust Algorithm for Reputation Management in P2P Networks
  • 原文地址:https://www.cnblogs.com/liujiaxin2018/p/15721571.html
Copyright © 2011-2022 走看看