binghai03 发表于 2018-8-15 11:12:25

python 中 print 函数用法大全

  有一道ctf题为:ASCII码而已
\u5927\u5bb6\u597d\uff0c\u6211\u662f\u0040\u65e0\u6240\u4e0d\u80fd\u7684\u9b42\u5927\u4eba\uff01\u8bdd\u8bf4\u5fae\u535a\u7c89\u4e1d\u8fc7\u767e\u771f\u7684\u597d\u96be\u3002\u3002\u0077\u0063\u0074\u0066\u007b\u006d\u006f\u0072\u0065\u006d\u006f\u0072\u0065\u005f\u0077\u0065\u0069\u0062\u006f\u005f\u0066\u0061\u006e\u0073\u007d  这是Unicode编码,题目是ASCII码xx,猜到题意:将Unicode码转换成ASCII码。 我用Python进行转换。

  一个简单的ctf题,我将print函数进行总结。
  在 Python 3 中接触的第一个很大的差异就是缩进是作为语法的一部分,这和C++等其他语言确实很不一样,所以要小心 ,其中python3和python2中print的用法有很多不同,python3中需要使用括号
  缩进要使用4个空格(这不是必须的,但你最好这么做),缩进表示一个代码块的开始,非缩进表示一个代码的结束。没有明确的大括号、中括号、或者关键字。这意味着空白很重要,而且必须要是一致的。第一个没有缩进的行标记了代码块,意思是指函数,if 语句、 for 循环、 while 循环等等的结束。
  输入很简单

[*]
[*]
[*]  x = input("Please input x:")
[*]  Please input x:


  输出的 print 函数总结:
  1. 字符串和数值类型
  可以直接输出

[*]
[*]
[*]  >>> print(1)
[*]  1
[*]  >>> print("Hello World")
[*]  Hello World


  2.变量
  无论什么类型,数值,布尔,列表,字典...都可以直接输出

[*]  >>> x = 12
[*]  >>> print(x)
[*]  12
[*]  >>> s = 'Hello'
[*]  >>> print(s)
[*]  Hello
[*]  >>> L =
[*]  >>> print(L)
[*]  
[*]  >>> t = (1,2,'a')
[*]  >>> print(t)
[*]  (1, 2, 'a')
[*]  >>> d = {'a':1, 'b':2}
[*]  >>> print(d)
[*]  {'a': 1, 'b': 2}
  3.格式化输出
  类似于C中的 printf

[*]  >>> s
[*]  'Hello'
[*]  >>> x = len(s)
[*]  >>> print("The length of %s is %d" % (s,x))
[*]  The length of Hello is 5
  (1). %字符:标记转换说明符的开始
  (2). 转换标志:-表示左对齐;+表示在转换值之前要加上正负号;“”(空白字符)表示正数之前保留空格;0表示转换值若位数不够则用0填充
  (3). 最小字段宽度:转换后的字符串至少应该具有该值指定的宽度。如果是*,则宽度会从值元组中读出。
  (4). 点(.)后跟精度值:如果转换的是实数,精度值就表示出现在小数点后的位数。如果转换的是字符串,那么该数字就表示最大字段宽度。如果是*,那么精度将从元组中读出
  (5).字符串格式化转换类型
  转换类型          含义
  d,i               带符号的十进制整数
  o                   不带符号的八进制
  u                   不带符号的十进制
  x                  不带符号的十六进制(小写)
  X                   不带符号的十六进制(大写)
  e                   科学计数法表示的浮点数(小写)
  E                   科学计数法表示的浮点数(大写)
  f,F               十进制浮点数
  g                   如果指数大于-4或者小于精度值则和e相同,其他情况和f相同
  G                  如果指数大于-4或者小于精度值则和E相同,其他情况和F相同
  C                  单字符(接受整数或者单字符字符串)
  r                  字符串(使用repr转换任意python对象)
  s                   字符串(使用str转换任意python对象)

[*]  >>> pi = 3.141592653
[*]  >>> print('%10.3f' % pi) #字段宽10,精度3
[*]  3.142
[*]  >>> print("pi = %.*f" % (3,pi)) #用*从后面的元组中读取字段宽度或精度
[*]  pi = 3.142
[*]  >>> print('%010.3f' % pi) #用0填充空白
[*]  000003.142
[*]  >>> print('%-10.3f' % pi) #左对齐
[*]  3.142
[*]  >>> print('%+f' % pi) #显示正负号
[*]  +3.141593
  4.如何让 print 不换行
  在Python中总是默认换行的

[*]  >>> for x in range(0,10):
[*]  print(x)
[*]
[*]
[*]  0
[*]  1
[*]  2
[*]  3
[*]  4
[*]  5
[*]  6
[*]  7
[*]  8
[*]  9
  如果想要不换行,之前的 2.x 版本可以这样 print x, 在末尾加上 ,
  但在 3.x 中这样不起任何作用
  要想换行你应该写成 print(x,end = '' )

[*]  >>> for x in range(0,10):
[*]  print (x,end = '')
[*]
[*]
[*]  0123456789
  拼接字符串:

[*]  >>> "Hello""World"
[*]  'HelloWorld'
[*]  >>> x = "Hello"
[*]  >>> y = "world"
[*]  >>> xy
[*]  Traceback (most recent call last):
[*]  File "<pyshell#10>", line 1, in <module>
[*]  xy
[*]  NameError: name 'xy' is not defined
[*]  >>> x+y
[*]  'Helloworld'
  pow函数:

[*]  # 2**3%5(2的3次幂对5取模)
[*]  >>> pow(2,3,5)
[*]  3
  然后很重要一点是类型可以自由地转换,你赋什么值,变量就是什么类型,python会自动帮你管理
  这点真让我的C++思维转不过来呢

[*]  >>> x = 2
[*]  >>> type(x)
[*]  <class 'int'>
[*]  >>> x = 2.3
[*]  >>> type(x)
[*]  <class 'float'>
[*]  >>> x =
[*]  >>> type(x)
[*]  <class 'list'>
  部分函数:
  abs(number),返回数字的绝对值
  cmath.sqrt(number),返回平方根,也可以应用于负数
  float(object),把字符串和数字转换为浮点数
  help(),提供交互式帮助
  input(prompt),获取用户输入
  int(object),把字符串和数字转换为整数
  math.ceil(number),返回数的上入整数,返回值的类型为浮点数
  math.floor(number),返回数的下舍整数,返回值的类型为浮点数
  math.sqrt(number),返回平方根不适用于负数
  pow(x,y[.z]),返回X的y次幂(有z则对z取模)
  repr(object),返回值的字符串标示形式
  round(number[.ndigits]),根据给定的精度对数字进行四舍五入
  str(object),把值转换为字符串
页: [1]
查看完整版本: python 中 print 函数用法大全