Linux:find命令中
2024-08-24 23:57:55
默认情况下, find 每输出一个文件名, 后面都会接着输出一个换行符 ('\n'), 因此我们看到的 find 的输出都是一行一行的:
ls -l
total 0
-rw-r--r-- 1 root root 0 2010-08-02 18:09 file1.log
-rw-r--r-- 1 root root 0 2010-08-02 18:09 file2.log
find -name '*.log'
./file2.log
./file1.log
比如我想把所有的 .log 文件删掉, 可以这样配合 xargs 一起用:
find -name '*.log'
./file2.log
./file1.log find -name '*.log' | xargs rmfind -name '*.log'
嗯, 不错, find+xargs 真的很强大. 然而:
ls -l
total 0
-rw-r--r-- 1 root root 0 2010-08-02 18:12 file 1.log
-rw-r--r-- 1 root root 0 2010-08-02 18:12 file 2.log find -name '*.log'
./file 1.log
./file 2.log find -name '*.log' | xargs rm
rm: cannot remove `./file': No such file or directory
rm: cannot remove `1.log': No such file or directory
rm: cannot remove `./file': No such file or directory
rm: cannot remove `2.log': No such file or directory
原因其实很简单, xargs 默认是以空白字符 (空格, TAB, 换行符) 来分割记录的, 因此文件名 ./file 1.log 被解释成了两个记录 ./file 和 1.log, 不幸的是 rm 找不到这两个文件.
为了解决此类问题, 聪明的人想出了一个办法, 让 find 在打印出一个文件名之后接着输出一个 NULL 字符 ('\0') 而不是换行符, 然后再告诉 xargs 也用 NULL 字符来作为记录的分隔符. 这就是 find 的 -print0 和 xargs 的 -0 的来历吧.
ls -l
total 0
-rw-r--r-- 1 root root 0 2010-08-02 18:12 file 1.log
-rw-r--r-- 1 root root 0 2010-08-02 18:12 file 2.log
find -name '*.log' -print0 | xargs -0 rmfind -name '*.log'
你可能要问了, 为什么要选 '\0' 而不是其他字符做分隔符呢? 这个也容易理解: 一般的编程语言中都用 '\0' 来作为字符串的结束标志, 文件的路径名中不可能包含 '\0' 字符.
最新文章
- ASP.NET TextBox 当鼠标点击后清空默认提示文字
- ListView适配器获取布局文件作为View的三种方式
- App开发的过程
- spark新能优化之序列化
- C语言文法 改
- Linux 命令 - find: 搜索文件
- glibc 安装( version `GLIBC_2.14' not found";)
- 基于iOS,Android的服务器证书失效检测
- 话说 MAX_FILE_SIZE
- configparser配置文件模块
- 【转】Jqgrid学习之数据
- Cesium原理篇:3D Tiles(2)数据结构
- WordCount项目基本功能
- AT2412 最大の和
- 【EF6学习笔记】(七)读取关联数据
- 牛客网 查找第K小数
- 在SQL中有时候我们需要查看现在正在SQL Server执行的命令
- Spring MVC基本配置和实践(二)
- Calendar 日期类介绍
- linux下route命令--说的比较清楚!
热门文章
- 【.NET 与树莓派】用 MPD 制作数字音乐播放器
- 常见yaml写法-job
- 大一C语言学习笔记(7)---指针篇--什么是指针?什么是指针变量?取地址符“&;”的作用是什么?地址运算符“*”的作用是什么,怎么理解两者?
- sql关联修改
- IDEA maven Run Maven 启动方式
- Python-Unittest多线程生成报告
- 导出 doc
- [cf1495F]Squares
- 在Ubuntu上安装Docker Engine
- 如何构建自己的KEGG数据库