前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python的标准输入,输出,错误输出。

python的标准输入,输出,错误输出。

作者头像
py3study
发布2020-01-13 00:14:12
3.6K0
发布2020-01-13 00:14:12
举报
文章被收录于专栏:python3python3

1:标准输入:

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

代码语言:javascript
复制
#!/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函数的输出默认的结果时多带一个换行符的,若想去掉换行符可以在左后面加一个>逗号

输出结果如下:

代码语言:javascript
复制
[root@lianxi1 Day01]# python Day01.py 
wer
rew
wer       #标准输出的结果
rew

wer        #print的输出
rew

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

代码语言:javascript
复制
#!/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)

输出结果如下:

代码语言:javascript
复制
[root@lianxi1 Day01]# python Day02.py 
dfs
sdf                    #输入结束后需要按ctrl-D结束。
2
[root@lianxi1 Day01]#

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

    需求:1.要实现wc的统计单词,统计字符,统计行数的功能。 2.若文件不存在则需要给出提示。

代码语言:javascript
复制
#!/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

结果如下:

代码语言:javascript
复制
[root@lianxi1 python100]# python lianxi1.py  /etc/hosts  /etc/passwd
2 10 158
31 52 1457
[root@lianxi1 python100]#

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

4.标准输出中的缓存。

代码语言:javascript
复制
#!/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选项效果一样

输出结果:

代码语言:javascript
复制
[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]# 注意官产三种方法的效果
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-08-26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档