python按行读取文件 去掉换行符"\n"

来源:互联网 发布:微谱数据库怎么进去 编辑:程序博客网 时间:2024/05/18 00:35

 

eg:

#! /usr/bin/pythonimport sysimport stringimport osbase_dir="/home/qinjianwang/mtr_dir/2012_09_12/tw"as_uniq_info=base_dir + "/as_uniq_info"get_line_num="wc -l " + as_uniq_info + " | awk '{print $1}'" ###get the lines of "as_uniq_info"line_num = os.popen(get_line_num).read().strip('\n')global VEXNUM 
VEXNUM = string.atoi(line_num)

python 字符串连接

base_dir="/home/qinjianwang/mtr_dir/2012_09_12/tw"as_uniq_info=base_dir + "/as_uniq_info"

有:as_uniq_info="/home/qinjianwang/mtr_dir/2012_09_12/tw/as_uniq_info"

需要注意以下这句:

get_line_num="wc -l " + as_uniq_info + " | awk '{print $1}'" ###get the lines of "as_uniq_info"
注意1:拼接shell命令时,需要引用python中的变量as_uniq_info,as_uniq_info单独拿出来,再拼接其它命令,不要写成下面这样:

get_line_num="wc -l as_uniq_info | awk '{print $1}'"
 这样写会造成shell无法正确替换python中的变量as_uniq_info。

注意2:拼接shell命令时,要注意引号中命令间的留空,如以下

"wc -l " 和  " | awk '{print $1}'"
引号"wc -l “中的 -l 后面就需要留空,要注意。


python 调用 shell

get_line_num="wc -l as_uniq_info | awk '{print $1}'" ###get the lines of "as_uniq_info"
line_num = os.popen(get_line_num).read().strip('\n')

 get_line_num 作为shell执行的命令,会取得文件as_uniq_info文件的行数

os.popen(get_line_num):执行shell

get_line_num = os.popen(get_line_num).read():调用read,赋值给get_line_num,此时get_line_num中含有一个换行符("\n")。

os.popen(get_line_num).read().strip('\n'):去掉换行符

 

shell 引用python变量

line_num = os.popen(get_line_num)

引用了python中的get_line_num变量。

 

python引用shell中值

line_num = os.popen(get_line_num).read()

执行完shell后,通过read()函数,赋值给python中的变量line_num

python 去掉换行符"\n" 

line_num = os.popen(get_line_num).read().strip('\n')

通过strip()函数,去掉换行符"\n" 

 

python按行读取文件 去掉换行符"\n"

for line in file.readlines():     line=line.strip('\n')

 Python 字符转实型 

b="123.678">>> string.atof(b)   123.678


 

 Python 字符转整型 

VEXNUM = string.atoi(line_num)