WC
- -c或--bytes或--chars 只显示Bytes数。
- -l或--lines 只显示列数。
- -w或--words 只显示字数。
- --help 在线帮助。
- --version 显示版本信息。
在默认的情况下,wc将计算指定文件的行数、字数,以及字节数。
wc testfile
执行结果:
3 92 598 testfile # testfile文件的行数为3、单词数92、字节数598
wc testfile testfile_1 testfile_2 #统计三个文件的信息
$ wc testfile testfile_1 testfile_2 #统计三个文件的信息
执行结果:
3 92 598 testfile #第一个文件行数为3、单词数92、字节数598
9 18 78 testfile_1 #第二个文件的行数为9、单词数18、字节数78
3 6 32 testfile_2 #第三个文件的行数为3、单词数6、字节数32
15 116 708 总用量 #三个文件总共的行数为15、单词数116、字节数708
wc * #统计该文件夹下所有的文件信息
PS
ps 的各选项参数:
l 长格式输出
u 按用户名和启动时间的顺序来显示进程;
j 用任务格式来显示进程
a 显示所有用户的所有进程(包括其他用户)
x 显示无控制终端的进程
r 显示运行中的进程
ww 避免详细参数被截断
“-e”与“A”参数效果相同,显示所有终端下的执行程序。
“e”:列出所有程序并显示每个程序所使用的环境变量。
“-f”:显示程序的UID,PID,PPID,C与STIME等信息。
“f”:与“-f”类似,只显示当前终端所有程序,展示的数据少一点
ps -aux
“-A”: 显示所有终端下的执行程序。
“-a”:显示所有终端机下执行的程序,除了阶段作业领导者之外。
“a”:显示现行终端下的所有程序,包括其他用户的程序。
“-u”: 以用户为主的格式来显示程序状况。
“x“:显示所有程序,不以终端来区分。
和 grep 结合使用:提取指定程序的进程。
• 查看所有的用户
cat /etc/passwd
查看所有的分组
cat /etc/group
根据进程号pid查看当前跑的进程:
1、lsof -i
如果没有lsof命令,可用yum安装:yum install lsof
lsof -i 用以显示符合条件的进程情况,lsof(list open files)是一个列出当前系统打开文件的工具。以root用户来执行lsof -i命令,如下图
【步骤二】lsof -i:端口号
lsof -i:端口号,用于查看某一端口的占用情况,比如查看22号端口使用情况,lsof -i:22,如下图
【步骤三】netstat -tunlp
netstat -tunlp用于显示tcp,udp的端口和进程等相关情况,如下图
2、netstat -tunlp|grep 端口号
【步骤四】netstat -tunlp|grep 端口号
netstat -tunlp|grep 端口号,用于查看指定端口号的进程情况,如查看22端口的情况,netstat -tunlp|grep 22,如下图
在linux中执行python程序时,我们通常会用 python xx.py命令来执行,但这样执行的程序在关闭linux的控制台后,执行的程序就退出了,要让程序关闭后继续执行该怎么办?
要让python程序在关闭控制台后继续执行,我们需要使用到nohub命令。
nohup是linux下的一个命令,其用途为不挂断地运行命令。
执行python时,命令格式如下:
nohup python -u xx.py > log.out 2>&1 &
1、1是标准输出(STDOUT)的文件描述符,2是标准错误(STDERR)的文件描述符1> log.out 简化为 > log.out,表示把标准输出重定向到log.out这个文件
2、2>&1 表示把标准错误重定向到标准输出,这里&1表示标准输出
为什么需要将标准错误重定向到标准输出的原因,是因为标准错误没有缓冲区,而STDOUT有。
就会导致commond > log.out 2> log.out文件log.out被两次打开,而STDOUT和STDERR将会竞争覆盖,这肯定不是我门想要的
标准输出的意思不是太懂,标准管道流输出
CentOS查看文件编码格式及文件编码转换
如果你需要在Linux 中操作windows下的文件 ,那么你可能会经常遇到文件 编码 转换的问题。Windows中默认的文件 格式是GBK(gb2312),而Linux 一般都是UTF-8。下面介绍一下,在Linux 中如何查看 文件 的编码 及如何进行对文件 进行编码 转换。
查看 文件 编码
在Linux 中查看 文件 编码 可以通过以下几种方式:
1.在Vim 中可以直接查看 文件 编码
:set fileencoding
即可显示文件 编码 格式。
如果你只是想查看 其它编码 格式的文件 或者想解决用Vim查看 文件 乱码的问题,那么你可以在
~/.vimrc 文件 中添加以下内容:
set encoding=utf-8 fileencodings=ucs-bom,utf-8,cp936
这样,就可以让vim自动识别文件 编码 (可以自动识别UTF-8或者GBK编码 的文件 ),其实就是依照 fileencodings提供的编码 列表尝试,如果没有找到合适的编码 ,就用latin-1(ASCII)编码 打开。
2. enca (如果你的系统中没有安装这个命令,可以用sudo yum install -y enca 安装 )查看 文件 编码
$ enca filename
filename: Universal transformation format 8 bits; UTF-8
CRLF line terminators
需要说明一点的是,enca对某些GBK编码 的文件 识别的不是很好,识别时会出现:
Unrecognized encoding
文件 编码 转换
1.在Vim中直接进行转换文件 编码 ,比如将一个文件 转换成utf-8格式
:set fileencoding=utf-8
2. enconv 转换文件 编码 ,比如要将一个GBK编码 的文件 转换成UTF-8编码 ,操作如下
enconv -L zh_CN -x UTF-8 filename
3. iconv 转换,iconv的命令格式如下:
iconv -f encoding -t encoding inputfile
比如将一个UTF-8 编码 的文件 转换成GBK编码
iconv -f GBK -t UTF-8 file1 -o file2
Linux 文件名编码转换
从Linux 往windows拷贝文件 或者从windows往Linux 拷贝文件 ,有时会出现中文文件 名 乱码的情况,出现这种问题的原因是因为,windows的文件 名 中文编码 默认为GBK,而Linux 中默认文件 名 编码 为UTF8,由于编码 不一致,所以导致了文件 名 乱码的问题,解决这个问题需要对文件 名 进行转码。
在Linux 中专门提供了一种工具convmv进行文件 名 编码 的转换 ,可以将文件 名 从GBK转换 成UTF-8编码 ,或者从UTF-8转换 到GBK。
首先看一下你的系统上是否安装了convmv,如果没安装的话用:
yum -y install convmv
安装。
下面看一下convmv的具体用法:
convmv -f 源编码 -t 新编码 [选项] 文件 名
常用参数:
-r 递归处理子文件 夹
--notest 真正进行操作,请注意在默认情况下是不对文件 进行真实操作的,而只是试验。
--list 显示所有支持的编码
--unescap 可以做一下转义,比如把%20变成空格
比如我们有一个utf8编码 的文件 名 ,转换 成GBK编码 ,命令如下:
convmv -f UTF-8 -t GBK --notest utf8编码 的文件 名
这样转换 以后"utf8编码 的文件 名 "会被转换 成GBK编码 (只是文件 名 编码 的转换 ,文件 内容不会发生变化)。
注意:不要在NTFS和FAT文件 系统中使用此命令,否则可能产生意外结果,如果要在Linux 中正确的显示NTFS和 FAT的中文件名,可以通过mount参数来解决,具体方法查看一下man手册。
浙公网安备 33010602011771号