输入和输出
用print()在括号中加上字符串,就可以向屏幕输出指定的字符 eg:
>>> print(‘hello, world‘)
print()函数也可以接受多个字符串,字符串之间用 “,” 逗号隔开 eg:
>>> print(‘The quick brown fox‘, ‘jumps over‘, ‘the lazy dog‘) The quick brown fox jumps over the lazy dog
print()会依次打印每个字符串,遇到逗号“,”会输出一个空格,因此,输出的字符串是这样拼起来的:
输出
Python提供了一个input(),可以让用户输入字符串,并存放到一个变量里。比如输入用户的名字:
>>>name = input() XiaoMing
当你输入 name = input() 并按下回车键时,python交互式命令行就在等待你输入了。这时,你可以输入任意字符,然后继续回车这时不会有任何
的提示。python交互命令行模式又回到了>>>状态了,这时,你可以
>>>name ‘XiaoMing‘
除了这种方式,也可以使用print()函数来输出
>>>print(‘name=‘,name) name=XiaoMing
input()函数也提供了一个可以让你用来提示用户输入。eg:
>>> name= input(‘pieas input your name:‘) pieas input your name:
这种格式的提供可以使在写 .py 脚本时 可以给用户提供更友好的交互
关于输出格式的一个问题
>>> name=input()Anne >>> print(‘Hello,‘,name,‘,that is a beautiful mame‘) Hello, Anne ,that is a beautiful mame
在Anne后面的逗号前有一个逗号去掉的方法
>>> print(‘Hello,‘,‘%s,‘%name,‘that is a beautiful name‘) Hello, Anne, that is a beautiful name >>> print(‘Hello,‘+name+‘,that is a beautiful name‘) Hello,Anne,that is a beautiful name >>> print(‘Hello,%s,this is a beautiful name‘%(name)) Hello,Anne,this is a beautiful name >>> print(‘Hello,%s,this is a beautiful name‘%name) Hello,Anne,this is a beautiful name
数据类型
整数
Python可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样,例如:1,100,-8080,0,等等。
计算机由于使用二进制,所以,有时候用十六进制表示整数比较方便,十六进制用0x前缀和0-9,a-f表示,例如:0xff00,0xa5b4c3d2,等等
浮点数
浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的,比如,1.23x109和12.3x108是完全相等的。
浮点数可以用数学写法,如1.23,3.14,-9.01,等等。但是对于很大或很小的浮点数,就必须用科学计数法表示,把10用e替代,1.23x109就是1.23e9,或者12.3e8,0.000012可以写成1.2e-5,等等。
整数和浮点数在计算机内部存储的方式是不同的,整数运算永远是精确的(除法难道也是精确的?是的!),而浮点数运算则可能会有四舍五入的误差。
字符串
字符串是以单引号‘或双引号"括起来的任意文本,比如‘abc‘,"xyz"等等。请注意,‘‘或""本身只是一种表示方式,不是字符串的一部分,因此,字符串‘abc‘只有a,b,c这3个字符。如果‘本身也是一个字符,那就可以用""括起来,比如"I‘m OK"包含的字符是I,‘,m,空格,O,K这6个字符。
如果字符串内部既包含‘又包含"怎么办?可以用转义字符\来标识,比如:
‘I\‘m \"OK\"!‘
>>> print(‘I\‘m\"OK\"‘) I‘m"OK"
转义字符 \
转义字符\可以转义很多字符,比如\n表示换行,\t表示制表符,字符\本身也要转义,所以\\表示的字符就是\
>>> print(‘I\‘m\"OK\"‘) I‘m"OK"
>>> print(‘I\‘m,ok‘) I‘m,ok
>>> print(‘I\‘m learning\nPython‘) I‘m learning Python
>>> print(‘\\\n\\‘) \
如果字符串内部有很多换行,用\n写在一行里不好阅读,为了简化,Python允许用‘‘‘...‘‘‘的格式表示多行内容,可以自己试试:
>>> print(‘‘‘line1 ... line2 ... line3‘‘‘) line1 line2 line3
布尔型
布尔值和布尔代数的表示完全一致,一个布尔值只有True、False两种值,要么是True,要么是False,在Python中,可以直接用True、False表示布尔值(请注意大小写),也可以通过布尔运算计算出来:
>>> True True >>> False False >>> 3 > 2 True >>> 3 > 5 False
布尔值可以用and、or和not运算。
and运算是与运算,只有所有都为True,and运算结果才是True
or运算是或运算,只要其中有一个为True,or运算结果就是True
not运算是非运算,它是一个单目运算符,把True变成False,False变成True
空值
空值是Python里一个特殊的值,用None表示。None不能理解为0,因为0是有意义的,而None是一个特殊的空值。
变量
变量在程序中就是用一个变量名表示了,变量名必须是大小写英文、数字和_的组合,且不能用数字开头
在Python中,等号 = 是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量 eg:
>>> a=123 >>> print(a) 123 >>> a=‘ABC‘ >>> print(a) ABC
常量
所谓常量就是不能变的变量,比如常用的数学常数π就是一个常量。在Python中,通常用全部大写的变量名表示常量。
在Python中,有两种除法,一种除法是/
>>> 10/3 3.3333333333333335
还有一种除法是//,称为地板除,两个整数的除法仍然是整数
>>> 10//3 3
Python还提供一个余数运算%,可以得到两个整数相除的余数
>>> 10%3 1
字符编码
因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理。最早的计算机在设计时采用8个比特(bit)作为一个字节(byte),所 以,一个字节能表示的最大的整数就是255(二进制11111111=十进制255),如果要表示更大的整数,就必须用更多的字节。比如两个字节可以表示 的最大整数是65535,4个字节可以表示的最大整数是4294967295。
Python提供了ord()函数获取字符的整数表示,chr()函数把编码转换为对应的字符:
>>> ord(‘A‘) 65 >>> ord(‘B‘) 66 >>> chr(36) ‘$‘ >>> chr(20013) ‘中‘
如果知道字符的整数编码,还可以用十六进制这么写str:
>>> ‘\u4e2d\u6587‘ ‘中文‘
>>> x=‘ABC‘ >>> print(x) ABC >>> x=b‘ABC‘ >>> print(x) b‘ABC‘
要注意区分‘ABC‘和b‘ABC‘,前者是str,后者虽然内容显示得和前者一样,但bytes的每个字符都只占用一个字节。
以Unicode表示的str通过encode()方法可以编码为指定的bytes,例如:
>>> ‘ABC‘.encode(‘ascii‘) b‘ABC‘
>>> ‘中文‘.encode(‘utf-8‘) b‘\xe4\xb8\xad\xe6\x96\x87‘
在bytes中,无法显示为ASCII字符的字节,用\x##显示。
如果我们从网络或磁盘上读取了字节流,那么读到的数据是 bytes 要把 bytes 变为 str ,就需要用 decode() 方法
>>> b‘ABC‘.decode(‘ascii‘) ‘ABC‘
>>> b‘\xe4\xb8\xad\xe6\x96\x87‘.decode(‘utf-8‘) ‘中文‘
本文出自 “启思·朝圣者” 博客,请务必保留此出处http://dearch.blog.51cto.com/10423918/1752687
原文地址:http://dearch.blog.51cto.com/10423918/1752687