# 设置为不可修改 chattr +i filename # 还原为可修改 chattr -i filename
ls -d */ ls -F | grep "/$" ls -l | grep "^d" find . -maxdepth 1 -type d -print
stat filename
command > /dev/null 2>&1 &
paste file1.txt file2.txt -d ","
# 命令名称其实是cat命令倒写 tac filename1 filename2 tac filename # 从stdin中读取 seq 5 | tac
# 比较归档中文件和文件系统有什么不一样: tar -df archive.tar # 排除版本控制的目录(包含子目录): tar --exclude-vcs -zcvf DataControl.tar.gz DataControl/
# 该命令会建立一个1MB大小的文件junk.data : if 表明输入文件(input file) # of 表明输出文件(output file), bs 表明以字节为单位的块大小(block size)
# count表明须要被复制的块数 dd if=/dev/zero of=./junk.data bs=1M count=1
分割文件成10k(xaa,xab,xac)
split -b 10k file.txtswift
以数字为后缀 (-d )(-a 后缀长度)
split -b 10k file.txt -d -a 4bash
自定义分割文件后缀 (split [COMMAND_ARGS] PREFIX)
split -b 10k file.txt -d -a 4 split_file版本控制
根据行数分割文件
split -l 10 file.txt -d -a 4 split_file日志
切分文件名和扩展名 (贪婪:匹配出最后一个扩展)
filename="Taylorswift.jpg"
文件名(%:非贪婪 %%:贪婪)(从右向左)
name=${filename%.*}
扩展名(#:非贪婪 %%:贪婪)(从左向右)
extension=${filename#*.}code
csplit分析文本,切割日志 (server.log)
SERVER-1
[connection] 192.168.0.1
[connection] 192.168.0.2
[disconnect] 192.168.0.3
[connection] 192.168.0.4
SERVER-2
[connection] 192.168.0.1
[connection] 192.168.0.2
[disconnect] 192.168.0.3
[connection] 192.168.0.4
SERVER-3
[connection] 192.168.0.1
[connection] 192.168.0.2
[disconnect] 192.168.0.3
[connection] 192.168.0.4server
csplit server.log /SERVER/ -s {*} -n 2 -f server -b "%02d.log";rm server00.log
/SERVER/ 用来匹配某一行,分割过程即今后处开始。
{*} 表示根据匹配重复执行分割,直到文件末尾为止。能够用{整数}的形式来指定分割执
行的次数。
-s 使命令进入静默模式,不打印其余信息。
-n 指定分割后的文件名后缀的数字个数,例如0一、0二、03等。
-f 指定分割后的文件名前缀(在上面的例子中,server就是前缀)
-b 指定后缀格式。例如 %02d.log ,相似于C语言中 printf 的参数格式。在这里文件名=
前缀+后缀= server + %02d.log
由于分割后的第一个文件没有任何内容(匹配的单词就位于文件的第一行中),因此咱们删
除了server00.logblog