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手册。