linux工作中常用文件操作命令

来源:互联网 发布:湖北楚天网络客服电话 编辑:程序博客网 时间:2024/06/08 10:18

本文主要是本人在使用linux的时候操作文件以及目录的常见的命令,主要内容如下:

  • ls 按照时间修改顺序列出文件,以M/G方式(human readable)显示出文件(如ls -lth) ,显示隐藏文件等

  • 判断文件是否存在test -f filename && echo “File exists”

  • 通配符文件的删除

  • 文件的移动(少了以及大量),批量重命名等

  • SecureCRT linux与win10下文件的传送(rz, sz)例如linux下大批量的文件传输到win10下

  • dh (disk usage) 目录大小查看,排序

  • linux文件(主要是代码的树型查看)

  • 文件查找(locate /find)

转载注明出处哈
“http://blog.csdn.net/haluoluo211/article/details/77714264”


ls

前段时间在linux上面跑C++程序的时候,偶尔程序会挂掉,这个时候我们需要通过core dump文件定位问题。而core dump文件有一大推我们需要安装最新的修改时间排序,显示的大小等信息:
这里写图片描述

然后在
sudo gdb AntiChatFilterd /data/core_files/core-AntiC659
通过gdb调试(注意上面省略了一些字符)

显示所有的文件,包括隐藏文件:ls -a
或者ls -ld .?*

按照最近修改时间排序 ls -lt (反向排序在ls -lrt)

最常用还有比如回到上一层目录 cd -

判断文件是否存在: test -f filename && echo “File exists”

通配符删除文件


一般 rm -f filename删除文件
比如我们要删除多个文件
rm -f 1.jpg 2.jpg 或者 rm -f {1,2}.jpg

rm -f *.jpg 删除所有的jpg

当rm 删除文件列表太长可以使用for循环
for f in *.pdf; do rm “$f”; done

文件移动重命名


比如重命名目录
mv /home/user/oldname /home/user/newname

当我们移动很多文件的时候,往往会报错参数太长
下面给出一个自己的示例
这里写图片描述

awk -F, ‘NR>1&&2==1{print1}’ submission_model_1_v1.csv | xargs mv –target-directory=result_1

上面通过 xagrs 把所有的图片通过参数,然后 mv到target directory中

或者(下面是移动文件并按照 0000x.jpg格式化重命名)
find -name ‘*.jpg’ \ # find jpg s
| awk ‘BEGIN{ a=0 }{ printf “mv \”%s\” %04d.jpg\n”, $0, a++ }’ # build mv command
| bash # run that command

文件批量重命名


比如我要把目录下所有的 png->jpg

rename 's/\.png$/\.jpg/' *.png# 或者for file in *.pngdo mv "$file" "${file%.png}.jpg"done

又比如想按照 0001~0010 ,jpg 这样的形式命名可以

find -name '*.jpg' \  # find png s| awk 'BEGIN{ a=0 }{ printf "mv \"%s\" %04d.jpg\n", $0, a++ }'  # build mv command| bash # run that command

这里写图片描述

sz /rz (以及批量linux文件->win10)


一般 sudo rz -bey (覆盖原有文件,一般不会传送终止,如果终止了一般 disconnect SecureCRT 然后重新回到目录下 rz -bey 即可)

linux文件-》win10下 一般 sz filename即可

但是传送大量文件就有问题,参数太长
也可以类似上面的for 循环
这里写图片描述

#!/bin/shread -p "input the class num: " classclass_num=`awk '$2=='$class' {class_num+=1;} END {print class_num}' train.txt`echo "$class  sample size is: $class_num"read -p "input the num of how many samples you wants to download: " download_numstep=$((class_num / download_num))echo "step size is $step"# all_files-> a.jpg b.jpg c.jpgall_files=`awk -v c="$class" '$2==c {print $1} ' train.txt `d_f=" "count=0for i in $all_filesdo    count=$(($count+1))    if [ $count -eq $step ]    then        count=0        d_f="$d_f  $i"  #there is a space between two variable    fi doneecho "after for loop, the end of sz"cd /data5/light/storm_1_1/imagessudo sz $d_fcd -

其中 train.txt 部分内容如下:

head -2 train.txt train/4C0/4C0B77F76A1C58DE372F984AA8A807BEFF04F63A.png 0train/4C0/4C0A77546E80894F8F89EE8D7AB8C7E159A99193.png 0tail -2 train.txt train/64f/64fc3277521ff37177cbb43329b891dcb8f01203.png 27train/9C9/9C999B0A7FBEA214C3C8546549447A9902151ACB.png 16

dh (disk usage) 目录大小查看,排序


先上个简单示例,查看boost的这个目录大小:

这里写图片描述

-h, --human-readable  print sizes in human readable format (e.g., 1K 234M 2G)(以合适的方式显示文件大小)-s, --summarize display only a total for each argument(显示总的大小)

dh -h --max-depth=1 *

这里写图片描述

这里写图片描述

sort -h 按照大小排序,-r反向排序(故而最大的在第一个)

这里写图片描述


linux文件(主要是代码的树型查看)


tree ( 查看项目的目录结构) sudo apt-get install tree

tree -d

etc|-- abrt|   |-- abrt-action-save-package-data.conf|   |-- abrt.conf|   |-- gpg_keys|   `-- plugins|       |-- CCpp.conf|       `-- python.conf

转载注明出处哈
“http://blog.csdn.net/haluoluo211/article/details/77714264”

文件查找(locate /find)


文件查找主要是find/locate一般locate查找比较快,但记得sudo updatedb(如果长时间没有更新)

locate -i new.txt (-i 忽略大小写Ignore Case )
find / -name “filename”
目的:在根目录“/”开始搜被称为filename的文件,“filename”文件名可以包含通配符(*,?)

Regular files only(当前目录下查找以my开头的文件查找)
$ find . -name ‘my*’ -type f

原创粉丝点击