第二章----python基础
概要:python是一种计算机编程语言,有自己的一套语法,编译器或者解释器负责把符合语法的程序代码翻译成CPU能识别的机器码,然后执行。python使用缩进来组织代码块,Python程序中大小写是敏感的。#是单行注释;
第一节:数据类型和变量
1.数据类型:计算机不仅可以处理数值,而且可以处理文本,图形,音频,视频,网页等数据,处理不同的数据需要定义不同的数据类型。我的理解呢,就是,对于不同的数据,计算机是不知道的,用户直接定义好,那么计算机可以直接识别出来现在处理的数据是什么样的数据,其实数据类型就是起到这个作用。
2.数据类型分类
整数:python可以处理任意大小的整数,写法和数学中的写法一毛一样,也可以用十六进制表示。
浮点数:其实就是小数,小数位数太多所以引入E,比如1.23e8相当于:1.23*10的8次方,整数在内存中存储是精确的,浮点数是不精确的。
字符串:是以单引号或者双引号括起来的任意文本。print(r'字符串内容')前边加上r表示该字符串不用转义。
print('''line1
line2
line3''')字符串内部有换行,则可以使用这种形式。
布尔值:一个布尔值只有True和False两种。布尔值可以用在and or not运算中,布尔值经常用于条件判断中。
空值:空值是一个特殊的值,用None表示,不能理解成0,0是有意义的,None是一个特殊的空值。
3.变量定义:必须以大小写英文,字母,数字和_组合,且不能以数字开头。python中同一个变量可以赋给不同的数据类型值,python是动态性语言。
理解变量在计算机内存中的表示:a = 'abc';python解释器做了两件事:第一,在内存中创建了'abc'字符串,第二,在内存中创建了变量a,并将它指向了字符串'abc'
4.常量:不能改变的变量,用全部大写的变量名来表示常量,
5.python中的除法:第一种:'/'除法的结果是浮点数,第二种:'//'除法的结果是整数。
注解:python的整数和浮点数都没有大小限制。
第二节:字符串和编码
首先:字符串也是一种数据类型,但是字符串涉及到一种编码问题,各国的语言不通,设计的编码也就不同。ASCII码,和Unicode编码的主要区别是:前者是一个字节表示一个字符,后者是两个字节表示一个字符。--可变长的字符编码UTF-8;计算机内存中的字符编码都是Unicode编码.
其次:在py3中字符串是以Unicode编码的,py的字符串支持多语言。ord()函数获取某个字符的整数表示。比如:ord('a') ,chr()函数把编码转换成对应的字符,比如:chr('66').
最后:python的字符串中一个字符对应于多个字节,要想通过网络传输,或者保存到磁盘中,必须把str转变为以字节为单位的bytes,比如x = b'abc'每个字符只占用一个字节。
明确encode()和decode()的用法;获取字符包含多少个字符用len(str)函数。计算字符串的字节数:len(b'str')
字符串格式化:通过'%'来格式化字符串
第三节:使用list和tuple
第一:list
定义:list也是一种数据类型,-->是列表类型,并且是一种有序集合,可以随时添加和删除其中的元素。自己理解:其实就是PHP中的数组吧。
举例:classmates = ['a','b','c'];变量classmates是一个list类型。获取list元素的个数用len()函数来处理。
访问:通过索引的形式访问list中的元素,比如:classmates[0]、classmates[1], 取最后一个元素方法:classmates[-1],倒数第二个:classmates[-2]
注解:超过list的索引的时候,会报IndexError错误,所以要记住索引的最大值为len(classmates)-1
特点:list是一个可变的有序表,可以给list中追加元素到末尾。
方法:
追加一个元素到末尾,classmates.append('d');
在指定的元素之后插入一个元素:classmates.insert(0,'z');
删除末尾的元素:classmates.pop()删除的结果是返回删除的元素值。
删除list中指定元素的值:classmates.pop(索引值) 举例:classmates.pop(0)
替换某个元素的值:classmates[索引值] = '值' 举例:classmates[0] = 'e'
注解:list中的元素也可以是不同的数据类型;list中可以还有list,(其实就相当于一维数组中还有一个一维数组)访问方式一样;list可以为空;
第二:tuple
定义:是一个有序列表,叫做元组,tuple中的元素值一旦初始化就不能在更改。和list不同的是:没有那些修改插入,删除的方法。
语法:classmates = ('a','b','c')
特殊:可变的tuple,也就是说tuple中可以包含有list,list其实是可以改变的。要理解这中方式。
总结:list和tuple是py中的内置的有序集合,list是可变的,tuple是不可变的。
第四节:条件判断
1.定义:计算机之所以可以自动化执行任务,是因为计算机自己可以进行条件判断。
2.语法:if <条件判断1>:
<语句执行1>
elif <条件判断2>:
<语句执行2>
else:
<语句执行3>
举例:
age = 28 if age >= 18:#条件判断 print('your age is',age)#执行语句块 print('adult') elif age >= 6: print('your age is',age) print('teenager') else: print('your age is',age) print('kids')
简写形式:if x:
print('语句') 只要x是非零数值,非空字符串,非空list都是为真。
3.特点:执行从上到下执行,只要有一个条件符合,就执行其中的语句,如果都不符合,就执行else中的语句,和其他语言的条件判断思想基本一致。
4.讨论input();input返回的是字符串型,不能和整数直接比较,需要进行转换才能和整数比较。
birth = int(input('birth:'))#将用户输入的值转换成整型 if birth <= 2000 print('00前') else: print('00后')
举例:
height = 1.75 weight = 80.5 bmi = weight/(height*height) print(bmi) if bmi <= 18.5: print('您的体重过轻,请补充营养') elif bmi>=18.5 and bmi<=25: print('您的体重正常,恭喜了') elif bmi>=25 and bmi<=28: print('您的体重过重') elif bmi>=28 and bmi<=32: print('您的体重肥胖') else: print('您过于肥胖,请节制')
第五节:循环
第一种:for x in....... 解释:把每个元素带入到x中,然后执行缩进块的语句
举例:
names = ['a','b','c'] for name in names: print(name)
举例:实现1--10之间的整数之和
sum = 0 for x in [1,2,3,4,5,6,7,8,9,10]: sum += x print(sum)
函数:range()生成一个整数序列。
举例:实现0--100之间的整数之和
sum = 0 for x in range(101): sum += x print(sum)
第二种:while循环
定义:只要条件满足,就不断循环,条件不满足就退出循环。
举例:实现0到100之间的奇数之和
sum = 0 n = 99 while n >0: sum += n n = n-2 print(sum)
解释:在循环内部中,n不断自减,直到n变为-1时,条件不再满足,在执行print(sum)语句。一定要明确循环的开始条件,结束条件。
举例:通过不同的循环方法实现,打印出'hello name'
第一种方法:for x in .....
L= ['a','b','c'] for name in L: print('hello',name)
第二种方法:while循环
L = ['a','b','c'] i = 0 while i < len(L): name = L[i] print('Hello',name) i = i+1
break:在循环中,通过break语句可以提前退出循环,-----一般是通过条件来判断,当满足该条件时,执行break语句,跳出当前循环,不在执行以下的代码。
举例:打印出1--100的数字
n = 1 while n < 101: print(n) n = n+1
通过break控制上述代码,只打印出1--10的数字
n = 1 while n < 101: if n>10: break print(n) n = n+1
continue:在循环过程中,可以通过continue来跳过当前循环,直接进入下一次循环
n = 1 while n < 11: n = n + 1 if n%2 == 0: continue print(n) 输出奇数
小结:break和continue都是控制循环输出的,break是直接跳出循环,结束循环;而continue是结束当前一次的循环直接执行下一次的循环。
使用场景:比如要取到某些特殊的值。通常配合if语句一起使用。
第六节:使用dict和set
第一个:dict
定义:Python内置的字典,其实就是key--value键值对,具有很快的查找速度
语法:d = {'key1':value1,'key2':value2,.........}
访问:d['key1'] 添加一个元素:d['key'] = value;当dict中没有这个key时,会报错。删除一个元素:dict.pop('key')相应 的value值也会删除
d = {'a':56,'b':45} d['c'] = 76 print(d)
注解:当多个key相同的时候,取最后一个值;dict内部的存放顺序和key放入的顺序无关;dict中的key是不可变对象。
避免key出现错误:第一种:'key' in dict 若存在返回True,否则返回False;第二种:使用dict的get方法,比如:d.get('key',指定的值)
list和dict的比较:
1.dict的查找和插入非常快,不会随着key的增加而变慢
2.dict需要占用大量的内存,内存浪费严重
而list:1.查找和插入的时间随着key的增多时间增加;2.占用空间少,内存浪费的少。
第二个:set
定义:十一组key的集合,但是不存储value,因为key不能重复,所以,在set中,没有重复的key.重复的元素在set中会被过滤掉。
语法:s = set([list])
方法:添加 s.add() 删除:s.remove()
set和dict的根本区别:set不存储value.
注解:
字符串是不可变对象,list是可变的。a = 'abc',变量a中存储的是abc字符串对象。
对于不变对象来说,调用对象自身的任意方法,也不会改变该对象自身的内容。相反,这些方法会创建新的对象并返回,这样,就保证了不可变对象本身永远是不可变的。
小结:明确dict和set的区别,以及python的基础知识要打牢。