Python(二) package及基本数据类型

插入包

import os
import requests
r=requests.get("https://cn.bing.com/")
print(r.url)
print(r.encoding)
print(r.text)

import requests

Unresolved import: requests
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述

数据类型

Python3 中有六个标准的数据类型:
Number(数字)
String(字符串)
List(列表)
Tuple(元组)
Sets(集合)
Dictionary(字典)
Python3 的六个标准数据类型中:
不可变数据(四个):Number(数字)、String(字符串)、Tuple(元组)、Sets(集合);
可变数据(两个):List(列表)、Dictionary(字典)。

print语句

print语句也可以跟上多个字符串,用逗号“,”隔开,就可以连成一串输出,print会依次打印每个字符串,遇到逗号“,”会输出一个空格,因此,输出的字符串是这样拼起来的


>>> print 300
300    #运行结果
>>> print 100 + 200
300    #运行结果

变量

  • 变量名

在Python程序中,变量是用一个变量名表示,变量名必须是大小写英文、数字和下划线”_”的组合,且不能用数字开头

a = 1
变量a是一个整数。
t_007 = ‘T007’
变量t_007是一个字符串。

  • 赋值
    在Python中,等号=是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量
a = 123       # a是整数
print a
a = 'imooc'   # a变为字符串
print a

这种变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言。静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错。例如Java是静态语言,赋值语句如下(// 表示注释):

int a = 123; // a是整数类型变量
a = "mooc"; // 错误:不能把字符串赋给整型变量

和静态语言相比,动态语言更灵活,就是这个原因。

a = 'ABC'
b = a
a = 'XYZ'
print b

输出结果:ABC
这里写图片描述
这里写图片描述
这里写图片描述

  • 练习

等差数列可以定义为每一项与它的前一项的差等于一个常数,可以用变量 x1 表示等差数列的第一项,用 d 表示公差,请计算数列1 4 7 10 13 16 19 …前 100 项的和

d=1
c=100
sum=0
while c > 0:
    sum=sum+d
    d=d+3
    c=c-1
print(sum)

字符串

  • 转义字符
    前面我们讲解了什么是字符串。字符串可以用”或者”“括起来表示。
    如果字符串本身包含’怎么办?比如我们要表示字符串 I’m OK ,这时,可以用” “括起来表示:
"I'm OK"

类似的,如果字符串包含”,我们就可以用’ ‘括起来表示:

'Learn "Python" in imooc'

如果字符串既包含’又包含”怎么办?
这个时候,就需要对字符串的某些特殊字符进行“转义”,Python字符串用\进行转义。
要表示字符串 Bob said “I’m OK”.
由于 ’ 和 ” 会引起歧义,因此,我们在它前面插入一个\表示这是一个普通字符,不代表字符串的起始,因此,这个字符串又可以表示为

'Bob said \"I\'m OK\".'

\n 表示换行
\t 表示一个制表符
\ 表示 \ 字符本身

  • raw字符串与多行字符串
    如果一个字符串包含很多需要转义的字符,对每一个字符都进行转义会很麻烦。为了避免这种情况,我们可以在字符串前面加个前缀 r ,表示这是一个 raw 字符串,里面的字符就不需要转义了。例如:r’(~_~)/ (~_~)/’
str=r'\(~_~)/ \(~_~)/'
print(str)

输出: \(~_~)/ (~_~)/
但是r’…’表示法不能表示多行字符串,也不能表示包含’和 “的字符串(为什么?)
如果要表示多行字符串,可以用”’…”’表示:

str='''Line 1
Line 2
Line 3'''
print(str)

输出:

Line 1
Line 2
Line 3
上面这个字符串的表示方法和下面的是完全一样的:

'Line 1\nLine 2\nLine 3'

还可以在多行字符串前面添加 r ,把这个多行字符串也变成一个raw字符串:

r'''Python is created by "Guido".
It is free and easy to learn.
Let's start learn Python in imooc!'''

Unicode字符串

Python在后来添加了对Unicode的支持,以Unicode表示的字符串用u’…’表示,比如:print u’中文’
注意: 不加 u ,中文就不能正常显示。
Unicode字符串除了多了一个 u 之外,与普通字符串没啥区别,转义字符和多行表示法仍然有效

u'''第一行
第二行'''

raw+多行:

ur'''Python的Unicode字符串支持"中文",
"日文",
"韩文"等多种语言'''

如果中文字符串在Python环境下遇到 UnicodeDecodeError,这是因为.py文件保存的格式有问题。可以在第一行添加注释

# -*- coding: utf-8 -*-
//u和上面这一句相同的意思,不要重复添加

布尔类型

我们已经了解了Python支持布尔类型的数据,布尔类型只有True和False两种值,但是布尔类型有以下几种运算:

与运算:只有两个布尔值都为 True 时,计算结果才为 True。

True and True     # ==> True
True and False    # ==> False
False and True    # ==> False
False and False   # ==> False

或运算:只要有一个布尔值为 True,计算结果就是 True。

True or True     # ==> True
True or False    # ==> True
False or True    # ==> True
False or False   # ==> False

非运算:把True变为False,或者把False变为True:

not True         # ==> False
not False        # ==> True
a = True
print a and 'a=T' or 'a=F'

计算结果不是布尔类型,而是字符串 ‘a=T’,这是为什么呢?
因为Python把0、空字符串”和None看成 False,其他数值和非空字符串都看成 True

rue and ‘a=T’ 计算结果是 ‘a=T’ 继续计算 ‘a=T’ or ‘a=F’ 计算结果还是 ‘a=T’
要解释上述结果,又涉及到 and 和 or 运算的一条重要法则:短路计算。
1. 在计算 a and b 时,如果 a 是 False,则根据与运算法则,整个结果必定为 False,因此返回 a;如果 a 是 True,则整个计算结果必定取决与 b,因此返回 b。
2. 在计算 a or b 时,如果 a 是 True,则根据或运算法则,整个计算结果必定为 True,因此返回 a;如果 a 是 False,则整个计算结果必定取决于 b,因此返回 b。

所以Python解释器在做布尔运算时,只要能提前确定计算结果,它就不会往后算了,直接返回结果。

猜你喜欢

转载自blog.csdn.net/wo164683812/article/details/80182130
今日推荐