专栏首页用户2442861的专栏linux工作中常用文件操作命令

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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/haluoluo211/article/details/77714264

本文主要是本人在使用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{print2==1{print 1}’ 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 *.png
do
 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/sh
read -p "input the class num: " class
class_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_num
step=$((class_num / download_num))
echo "step size is $step"
# all_files-> a.jpg b.jpg c.jpg
all_files=`awk -v c="$class" '$2==c {print $1} ' train.txt `
d_f=" "
count=0
for i in $all_files
do
    count=$(($count+1))
    if [ $count -eq $step ]
    then
        count=0
        d_f="$d_f  $i"  #there is a space between two variable
    fi 
done
echo "after for loop, the end of sz"
cd /data5/light/storm_1_1/images
sudo sz $d_f
cd -

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

head -2 train.txt 
train/4C0/4C0B77F76A1C58DE372F984AA8A807BEFF04F63A.png 0
train/4C0/4C0A77546E80894F8F89EE8D7AB8C7E159A99193.png 0

tail -2 train.txt 
train/64f/64fc3277521ff37177cbb43329b891dcb8f01203.png 27
train/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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python入门笔记(15):对文件的操作(1)

    http://www.cnblogs.com/BeginMan/p/3166644.html

    bear_fish
  • Tesseract:训练

    http://www.zmonster.me/2015/05/05/tesseract-training.html

    bear_fish
  • 我的VS2010+VAssistX

    最近越来越觉得VAssistX好用,可能是以前没有去仔细研究过吧,也可能是因为我是个快捷键控吧,不管怎样,用或不用,方便或不方便,它就是那里,一动也不动,进入...

    bear_fish
  • PostgreSQL文件扩展机制

    扩展的底层函数为mdextend。先通过_mdfd_getseg获取指定页号的段文件描述符,然后根据页号计算出偏移,向该偏移出写入一页:大部分情况...

    yzsDBA
  • 关于正则优先级踩的坑【匹配图片后缀结尾】

    其实之前还真没注意到正则表达式总还有“优先级”这一说法。不过平常注意一下就可以了【踩过一次坑之后自然就会记住了~】。

    无道
  • macOS 开发 - 小基础拾遗

    通过熟悉一个App的启动过程,有利于我们理解开发时代码的执行过程,以及帮助我们修复一些系统Bug都是非常有意义的.一个macOS的App启动与iOS App启动...

    代码行者
  • 从没见过干净图片,英伟达AI就学会了去噪大法 | ICML论文

    量子位
  • (26)Bash变量测试与内容替换

    可能有人会说,你这不麻烦吗?我直接“echo $y”不就行了吗?其实echo是直接输出这个值,这个输出是给用户看的,我们在写脚本的时候,程序需要自动执行,他有可...

    生信real
  • 如何在linux服务器上使用hanlp

    关于如何在linux服务器上使用hanlp也有分享过一篇,但分享的内容与湘笑的这篇还是不同的。此处分享一下湘笑的这篇hanlp在linux服务器上使用的文章,供...

    IT小白龙
  • Scrapy框架-Spider和Craw

    http://wz.sun0769.com/index.php/question/questionType?type=4&page=

    py3study

扫码关注云+社区

领取腾讯云代金券