输入和输出
用print()在括号中加上字符串,就可以向屏幕输出指定的字符 eg:
1
|
>>> print ( 'hello, world' )
|
print()函数也可以接受多个字符串,字符串之间用 “,” 逗号隔开 eg:
1
2
|
>>> print ( 'The quick brown fox' , 'jumps over' , 'the lazy dog' )
The quick brown fox jumps over the lazy dog |
print()
会依次打印每个字符串,遇到逗号“,”会输出一个空格,因此,输出的字符串是这样拼起来的:
输出
Python提供了一个input()
,可以让用户输入字符串,并存放到一个变量里。比如输入用户的名字:
1
2
|
>>>name = input ()
XiaoMing |
当你输入 name = input() 并按下回车键时,python交互式命令行就在等待你输入了。这时,你可以输入任意字符,然后继续回车这时不会有任何
的提示。python交互命令行模式又回到了>>>状态了,这时,你可以
1
2
|
>>>name 'XiaoMing' |
除了这种方式,也可以使用print()函数来输出
1
2
|
>>> print ( 'name=' ,name)
name = XiaoMing
|
input()函数也提供了一个可以让你用来提示用户输入。eg:
1
2
|
>>> name = input ( 'pieas input your name:' )
pieas input your name:
|
这种格式的提供可以使在写 .py 脚本时 可以给用户提供更友好的交互
关于输出格式的一个问题
1
2
3
|
>>> name = input ()Anne
>>> print ( 'Hello,' ,name, ',that is a beautiful mame' )
Hello, Anne ,that is a beautiful mame
|
在Anne后面的逗号前有一个逗号去掉的方法
1
2
3
4
5
6
7
8
|
>>> 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\"!'
1
2
|
>>> print ( 'I\'m\"OK\"' )
I'm "OK"
|
转义字符 \
转义字符\
可以转义很多字符,比如\n
表示换行,\t
表示制表符,字符\
本身也要转义,所以\\
表示的字符就是\
1
2
|
>>> print ( 'I\'m\"OK\"' )
I'm "OK"
|
1
2
|
>>> print ( 'I\'m,ok' )
I'm,ok |
1
2
3
|
>>> print ( 'I\'m learning\nPython' )
I'm learning Python |
1
2
3
|
>>> print ( '\\\n\\' )
\ \ |
如果字符串内部有很多换行,用\n写在一行里不好阅读,为了简化,Python允许用'''...'''的格式表示多行内容,可以自己试试:
1
2
3
4
5
6
|
>>> print ( '''line1
... line2 ... line3''' )
line1 line2 line3 |
布尔型
布尔值和布尔代数的表示完全一致,一个布尔值只有True
、False
两种值,要么是True
,要么是False
,在Python中,可以直接用True
、False
表示布尔值(请注意大小写),也可以通过布尔运算计算出来:
1
2
3
4
5
6
7
8
|
>>> 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:
1
2
3
4
5
6
|
>>> a = 123
>>> print (a)
123 >>> a = 'ABC'
>>> print (a)
ABC |
常量
所谓常量就是不能变的变量,比如常用的数学常数π就是一个常量。在Python中,通常用全部大写的变量名表示常量。
在Python中,有两种除法,一种除法是/
1
2
|
>>> 10 / 3
3.3333333333333335 |
还有一种除法是//
,称为地板除,两个整数的除法仍然是整数
1
2
|
>>> 10 / / 3
3 |
Python还提供一个余数运算%,可以得到两个整数相除的余数
1
2
|
>>> 10 % 3
1 |
字符编码
因为计算机只能处理数字,如果要处理文本,就必须先把文本转换为数字才能处理。最早的计算机在设计时采用8个比特(bit)作为一个字节(byte),所 以,一个字节能表示的最大的整数就是255(二进制11111111=十进制255),如果要表示更大的整数,就必须用更多的字节。比如两个字节可以表示 的最大整数是65535
,4个字节可以表示的最大整数是4294967295
。
Python提供了ord()
函数获取字符的整数表示,chr()
函数把编码转换为对应的字符:
1
2
3
4
5
6
7
8
|
>>> ord ( 'A' )
65 >>> ord ( 'B' )
66 >>> chr ( 36 )
'$' >>> chr ( 20013 )
'中' |
如果知道字符的整数编码,还可以用十六进制这么写str:
1
2
|
>>> '\u4e2d\u6587'
'中文' |
1
2
3
4
5
6
|
>>> x = 'ABC'
>>> print (x)
ABC >>> x = b 'ABC'
>>> print (x)
b 'ABC'
|
要注意区分'ABC'
和b'ABC'
,前者是str
,后者虽然内容显示得和前者一样,但bytes
的每个字符都只占用一个字节。
以Unicode表示的str
通过encode()
方法可以编码为指定的bytes
,例如:
1
2
|
>>> 'ABC' .encode( 'ascii' )
b 'ABC'
|
1
2
|
>>> '中文' .encode( 'utf-8' )
b '\xe4\xb8\xad\xe6\x96\x87'
|
在bytes
中,无法显示为ASCII字符的字节,用\x##
显示。
如果我们从网络或磁盘上读取了字节流,那么读到的数据是 bytes 要把 bytes 变为 str ,就需要用 decode() 方法
1
2
|
>>> b 'ABC' .decode( 'ascii' )
'ABC' |
1
2
|
>>> b '\xe4\xb8\xad\xe6\x96\x87' .decode( 'utf-8' )
'中文'
|