1:标准输入:

    python中的sys模块有标准输入,标准输出,以及标准错误输出的方法。

#!/usr/bin/env python
#coding:utf-8   #添加中文输出

import sys
fd = sys.stdin  #程序等待输入
data = fd.read()  #把输入的值赋给变量
sys.stdout.write(data + "\n") #借助于write方法把data的值传送给标准输出。
print data,
#print data  #也可以借助于print函数来输出,print函数的输出默认的结果时多带一个换行符的,若想去掉换行符可以在左后面加一个>逗号

输出结果如下:

[root@lianxi1 Day01]# python Day01.py 
wer
rew
wer       #标准输出的结果
rew

wer        #print的输出
rew

2:从标准输入统计输入的行数:

#!/usr/bin/env python
#coding:utf-8
#统计行数,实现wc -l的功能
import sys
def lineCount(fd): #定义函数第二个单词首字母大写。类每一个单词的首字母大写
    n = 0
    for i in fd: #fd是文件对象(可以直接遍历),可以换为fd.readlines(),返回的是一个列表

       n += 1
    return n
fd = sys.stdin
print lineCount(fd)

输出结果如下:

[root@lianxi1 Day01]# python Day02.py 
dfs
sdf                    #输入结束后需要按ctrl-D结束。
2
[root@lianxi1 Day01]#

3.用python编程实现wc的功能。

    需求:1.要实现wc的统计单词,统计字符,统计行数的功能。

        2.若文件不存在则需要给出提示。

#!/usr/bin/env python
#coding:utf-8

#导入模块
import sys, os
#!/usr/bin/env python
#coding:utf-8

#导入模块
import sys, os
if len(sys.argv) > 1 :#可以统计多个文件
    for i in sys.argv[1:]:
        #判断文件是否存在
        if not os.path.exists(i):
            print "%s is not exists" % i
            sys.exit()
        fd = open(i)
        data = fd.read()
        lens = data.count('\n')
        words = len(data.split())
        chars = len(data)
        print lens, words, chars
else:
    data = sys.stdin.read()
    lens = data.count('\n')
    words = len(data.split())
    chars = len(data)
    print lens, words, chars

结果如下:

[root@lianxi1 python100]# python lianxi1.py  /etc/hosts  /etc/passwd
2 10 158
31 52 1457
[root@lianxi1 python100]#

这个wc的功能不是很完善,只是做了一些统计而已。

4.标准输出中的缓存。

#!/usr/bin/env python
#coding:utf-8
import sys
import time
for i in range(10):
    sys.stdout.write("str:%d\n" %i)#一秒出一个
    time.sleep(1)
    #sys.stdout.flush() #刷新缓存,执行的加-u选项效果一样

输出结果:

[root@lianxi1 Day01]# python Day05.py  
str:0
str:1
str:2
str:3
str:4
str:5
str:6
str:7
str:8
str:9
[root@lianxi1 Day01]# python Day05.py  | cat -
str:0
str:1
str:2
str:3
str:4
str:5
str:6
str:7
str:8
str:9
[root@lianxi1 Day01]# python -u Day05.py  | cat -#‘-’是对输出流用cat来处理
str:0
str:1
str:2
str:3
str:4
str:5
str:6
str:7
str:8
str:9
[root@lianxi1 Day01]# 注意官产三种方法的效果