输入和输出
用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‘) ‘中文‘