[Python]print vs sys.stdout.write

之前只是在项目中看到过,没怎么注意,正好跟对象一起看python学习手册,看到了这个部分于是来研究下。

python版本 2.7.x

os  win7

print

一般就是执行脚本的时候,把信息直接打印到标准输出,也就是我们通常说的控制台

print是python __builtin__ 中的一个方法,来看看他的定义

def print(stream):
  """ print(value, ..., sep=' ', end='\\n', file=sys.stdout)

  Prints the values to a stream, or to sys.stdout by default.
  Optional keyword arguments:
  file: a file-like object (stream); defaults to the current sys.stdout.
  sep:  string inserted between values, default a space.
  end:  string appended after the last value, default a newline. """
  pass

从这里我们就能看到print也许比我们常用的功能多一些

* sep 用来做values之间的分割符,所以当我们 print ‘2‘, ‘a‘ 的时候,实际中间是空格

* end 默认是换行,所以print总是打印一行信息

* 其实print还可以输出到文件中

但我们又知道python2中的print 后面是没有参数列表的

In [2]: print ('a', 'b', sep='|')
  File "<ipython-input-2-bcb798285c07>", line 1
    print ('a', 'b', sep='|')
                        ^
SyntaxError: invalid syntax

哦噢,报错了,其实只要 from __future__ import print_function 就可以像python3一样使用参数了

In [6]: print('a', 'b')
a b

In [7]: print('a', 'b', sep='--')  #print 多个values 不用逗号分隔
a--b

In [8]: print('nihao');print('orangle')
nihao
orangle

In [9]: print('nihao', end='');print('orangle')  #print 不换行
nihaoorangle

好像print也有不少玩法哦

我们直接把print的值写到文件对象中,而不是默认的sys.stout试

In [11]: f = open('test.txt', 'w')
In [12]: print('haha.....csdn', file=f)
In [15]: ls test.txt
 驱动器 D 中的卷没有标签。
 卷的序列号是 0002-FA2E
 D:\code\python 的目录
2015/01/20 周二  10:37                 0 test.txt
               1 个文件              0 字节
               0 个目录 61,124,526,080 可用字节
In [16]: f.close()

到对应的目录下看看,test.txt的内容,果然是 haha.....csdn, 不过一定要记得 f.close(), 如果不关闭,内容是无法保存到文件中的。

sys.stdout.write

这个方法调用的是 ,file 对象中的write方法 ,把字符写到标准输出中,看起来跟print 差不多。

  def write(self, str):
    """ write(str) -> None.  Write string str to file.

    Note that due to buffering, flush() or close() may be needed before
    the file on disk reflects the data written. """
    return ""

关系

这个方法和print什么关系呢? 我们来查查

可以认为 print是对 sys.stdout.write的友好封装,也只是从 python学习手册这样看到。

区别

print 可以把一个对象转化成str然后放到标准输出中, sys.stdout.write 需要把对象先转化成对象在输出

In [3]: class A():
   ...:     def __str__(self):
   ...:         return "A"
   ...:

In [5]: a = A()
In [6]: print a
A

In [9]: import sys
In [10]: sys.stdout.write(a)
---------------------------------------------------------------------------
TypeError                                 Traceback (most recent call last)
<ipython-input-10-0697f962911e> in <module>()
----> 1 sys.stdout.write(a)

TypeError: expected a character buffer object

In [11]: sys.stdout.write(str(a))
A

所以说不能用 sys.stdout.write来直接代替 print

运用

这里两者怎么结合使用?

引用 Learning Python 中的一段代码

import sys
temp = sys.stdout #store original stdout object for later
sys.stdout = open('log.txt','w') #redirect all prints to this log file
print("testing123") #nothing appears at interactive prompt
print("another line") #again nothing appears. It is instead written to log file
sys.stdout.close() #ordinary file object
sys.stdout = temp #restore print commands to interactive prompt
print("back to normal") #this shows up in the interactive prompt

log.txt文件中保存输出结果为

testing123
another line

我们可以把调试中打印的信息保存的文件中,这样也是追中和查找错误的一个方式

还有就是多线程日志中可能会用到
sys.stdout.write 来封装日志写入

参考文章:

http://woodpecker.org.cn/diveintopython/scripts_and_streams/stdin_stdout_stderr.html

http://stackoverflow.com/questions/3263672/python-the-difference-between-sys-stdout-write-and-print

本文出自 “orangleliu笔记本”博客,转载请务必保留此出处http://blog.csdn.net/orangleliu/article/details/42915501

作者orangleliu 采用署名-非商业性使用-相同方式共享协议

时间: 2024-08-03 11:27:46

[Python]print vs sys.stdout.write的相关文章

python print &#183; sys.stdout &#183; sys.stderr

参考文档 Python重定向标准输入.标准输出和标准错误 http://blog.csdn.net/lanbing510/article/details/8487997 python重定向sys.stdin.sys.stdout和sys.stderr http://www.cnblogs.com/guyuyuan/p/6885448.html 1.print print obj 事实上是调用了sys.stdout.write(obj+'\n'),注意多了一个换行符 1a. print在pytho

python 之sys.stdout小记

标准输出(sys.stdout)-->print(打印) 标准输入(sys.stdin)-->input(接收输入) 标准错误输出和标准输出类似也是print(打印). python最基本的操作 - 打印: print 1 其效果是把 1 写在console(命令行)里面让你看. 也可以理解为:把console(命令行)作为一个板子,通过sys.stdout = console指定往console板子上写东西(console是默认的,也就是说你不修改要往哪儿写的话,就会默认往这写),在prin

python 以标准输出(sys.stdout)为例,看python的标准输入、标准错误输出

看了一个博客,挺不错的.http://www.cnblogs.com/turtle-fly/p/3280519.html 标准输出(sys.stdout)对应的操作就是print(打印)了,标准输入(sys.stdin)则对应input(接收输入)操作,标准错误输出和标准输出类似也是print(打印). python最基本的操作 - 打印: print 1 其效果是把 1 写在console(命令行)里面让你看. 实际上他的操作可以理解为:把console(命令行)作为一个板子,通过sys.st

Python标准库:内置函数print(*objects, sep=&#39; &#39;, end=&#39;\n&#39;, file=sys.stdout, flush=False)

本函数是实现对象以字符串表示的方式格式化输出到流文件对象file里.其中所有非关键字参数都按str()方式进行转换为字符串输出,关键字参数sep是实现分隔符,比如多个参数输出时想要输出中间的分隔字符:关键字参数end是输出结束时的字符,默认是换行符\n:关键字参数file是定义流输出的文件,可以是标准的系统输出sys.stdout,也可以重定义为别的文件:参数flush是立即把内容输出到流文件,不作缓存. 例子: #print() print(1, 2, 3, sep = ',', end =

python 中sys.stdout.write 和 print &gt;&gt; sys.stdout的区别

print >> sys.stdout的形式就是print的一种默认输出格式,等于print "%VALUE%" 看下面的代码的英文注释,是print的默认帮助信息 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 # coding=utf-8 import sys, os list1Display = ['1', '2', '3'] list2Display = ['abc', 'def', 'rfs'] while list2Displ

Python 标准输出 sys.stdout 重定向

使用 print obj 而非 print(obj) 一些背景 sys.stdout 与 print 当我们在 Python 中打印对象调用 print obj 时候,事实上是调用了 sys.stdout.write(obj+'\n') print 将你需要的内容打印到了控制台,然后追加了一个换行符 print 会调用 sys.stdout 的 write 方法 以下两行在事实上等价: sys.stdout.write('hello'+'\n') print 'hello' sys.stdin

python的sys.stdout重定向

一些背景 sys.stdout 与 print 当我们在 Python 中打印对象调用 print obj 时候,事实上是调用了 sys.stdout.write(obj+'\n') print 将你需要的内容打印到了控制台,然后追加了一个换行符 print 会调用 sys.stdout 的 write 方法 以下两行在事实上等价: sys.stdout.write('hello'+'\n') print 'hello' sys.stdin 与 raw_input 当我们用 raw_input(

python重定向sys.stdin、sys.stdout和sys.stderr

标准输入.标准输出和错误输出. 标准输入:一般是键盘.stdin对象为解释器提供输入字符流,一般使用raw_input()和input()函数. 例如:让用户输入信息(Python环境为2.x): 1 #!/usr/bin/python 2 # -*- coding: utf-8 -*- 3 import sys 4 name = raw_input("Please input your name: ") 5 print name 6 7 # python test.py 8 Plea

Python的sys.stdout、sys.stdin重定向

Python的sys.stdout.sys.stdin重定向 转自:http://www.cnblogs.com/turtle-fly/p/3280519.html 本文环境:Python 2.7 使用 print obj 而非 print(obj) 一些背景 sys.stdout 与 print 当我们在 Python 中打印对象调用 print obj 时候,事实上是调用了 sys.stdout.write(obj+'\n') print 将你需要的内容打印到了控制台,然后追加了一个换行符