据廖雪峰python3教程----python学习第二天

输入和输出

用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()会依次打印每个字符串,遇到逗号“,”会输出一个空格,因此,输出的字符串是这样拼起来的:spacer.gif

输出

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可以处理任意大小的整数,当然包括负整数,在程序中的表示方法和数学上的写法一模一样,例如:1100-80800,等等。

      计算机由于使用二进制,所以,有时候用十六进制表示整数比较方便,十六进制用0x前缀和0-9,a-f表示,例如:0xff000xa5b4c3d2,等等

浮点数

      浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的,比如,1.23x109和12.3x108是完全相等的。

      浮点数可以用数学写法,如1.233.14-9.01,等等。但是对于很大或很小的浮点数,就必须用科学计数法表示,把10用e替代,1.23x109就是1.23e9,或者12.3e8,0.000012可以写成1.2e-5,等等。


整数和浮点数在计算机内部存储的方式是不同的,整数运算永远是精确的(除法难道也是精确的?是的!),而浮点数运算则可能会有四舍五入的误差。


字符串

      字符串是以单引号'或双引号"括起来的任意文本,比如'abc'"xyz"等等。请注意,''""本身只是一种表示方式,不是字符串的一部分,因此,字符串'abc'只有abc这3个字符。如果'本身也是一个字符,那就可以用""括起来,比如"I'm OK"包含的字符是I'm,空格,OK这6个字符。

      如果字符串内部既包含'又包含"怎么办?可以用转义字符\来标识,比如:

          'I\'\"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


布尔型

    布尔值和布尔代数的表示完全一致,一个布尔值只有TrueFalse两种值,要么是True,要么是False,在Python中,可以直接用TrueFalse表示布尔值(请注意大小写),也可以通过布尔运算计算出来:

>>> True
True
>>> False
False
>>> 3 > 2
True
>>> 3 > 5
False




布尔值可以用andornot运算。

  and运算是与运算,只有所有都为Trueand运算结果才是True

  or运算是或运算,只要其中有一个为Trueor运算结果就是True

  not运算是非运算,它是一个单目运算符,把True变成FalseFalse变成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')
'中文'


你可能感兴趣的:(python,输入,基础学习)