2020-01-29 python学习记录(1)-基础语法

基础语法:

数据类型:

1、整数: 1,10,-100,0

2、浮点数是:1.1,2.1

3、字符串:'i am good man !',"i ' m  a good man" '''i am good man '''

4、布尔值:True、False(布尔值可以用and、or和not运算)

5、空值:用None表示。None不能理解为0,因为0是有意义的,而None是一个特殊的空值。

6、变量:a=1 ,a='good'

7、常量:10%3 ( 赋值 = 、加 + 、减 - 、乘 * 、除 /、取余数 % 、除后取整数 //)

字符串和编码:(8个比特(bit)作为一个字节(byte))

1、字符编码:ASCII、Unicode和UTF-8的关系

2、Python的字符串:str、ord()函数获取字符的整数表示,chr()函数把编码转换为对应的字符

Python对bytes类型的数据用带b前缀的单引号或双引号表示:x = b'ABC'

类型转换:decode()方法 -在工作中基本上是utf-8(*.decode('utf-8', errors='ignore'))

3、获取字符(列表)长度:len()

4、在python3中的编码-中文的显示正常:

#!/usr/bin/env python3 # -*- coding: utf-8 -*-

5、格式化:类似C语言的格式化

print('i am %s ,i age %d' %('cat',1))

几种格式化的数据类型:

占位符

替换内容

%d

整数

%f

浮点数

%s

字符串

%x

十六进制整数

6、format():格式化的形式

print('i am {} ,i age {}'.format('cat',12))

使用list和tuple:

1、list列表: 格式list=['test', 'test2', 'test3']

可以通过append()函数在list追加元素

通过索引号来选取对应的数值:注意list的下标开始为list[0] <第一个>,list[-1] <是最后一个>。

list[0] ='tomcat' 修改对应角标的值

要删除list末尾的元素,用pop()方法,同时pop(i)角标直接删除对应的数据。

2、tuple元组:

tuple和list非常类似,但是tuple一旦初始化就不能修改。

如果要定义一个空的tuple,可以写成()

只有1个元素的tuple定义时必须加一个逗号,,来消除歧义:

可变的tuple是嵌套list,可以修改list的可以让其变,其实tuple没有改变

练习:可变的tuple打印不同位置的值

条件判断:

1、条件判断:

if 判断语句:  else来实现

多个判断 if 判断语句: elif 判断语句: else多个嵌套

只要 判断语句是非零数值、非空字符串、非空list等,就判断为True,否则为False。

循环:

1、for

for x in ...循环就是把每个元素代入变量x,然后执行缩进块的语句。

2、while

只要为true就继续执行循环。

break是结束整个大循环

continue 结束当前循环,直接进入下一个循环。

小结:

break语句可以在循环过程中直接退出循环,而continue语句可以提前结束本轮循环,并直接开始下一轮循环。这两个语句通常都必须配合if语句使用。

使用dict和set:

1、dict字典:主要是 (键-值(key-value)存储),方便查询。

一个key只能对应一个value,所以,多次对一个key放入value,后面的值会把前面的值冲掉:

key不存在是会报错的:

要避免key不存在的错误,有两种办法,一是通过in判断key是否存在:

二是通过dict提供的get()方法,如果key不存在,可以返回None,或者自己指定的value:

注意:返回None的时候Python的交互环境不显示结果。

要删除一个key,用pop(key)方法,对应的value也会从dict中删除:

请务必注意,dict内部存放的顺序和key放入的顺序是没有关系的。

和list比较,dict有以下几个特点:

查找和插入的速度极快,不会随着key的增加而变慢;

需要占用大量的内存,内存浪费多。

而list相反:

查找和插入的时间随着元素的增加而增加;

占用空间小,浪费内存很少。

所以,dict是用空间来换取时间的一种方法。

dict可以用在需要高速查找的很多地方,在Python代码中几乎无处不在,正确使用dict非常重要,需要牢记的第一条就是dict的key必须是不可变对象。

这是因为dict根据key来计算value的存储位置,如果每次计算相同的key得出的结果不同,那dict内部就完全混乱了。这个通过key计算位置的算法称为哈希算法(Hash)。

要保证hash的正确性,作为key的对象就不能变。在Python中,字符串、整数等都是不可变的,因此,可以放心地作为key。而list是可变的,就不能作为key

2、set:(没有重复的key值)

set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。

重复的元素会被set过滤掉:

通过add(key)方法可以添加元素到set中,可以重复添加,但不会有效果:

通过remove(key)方法可以删除元素:

set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:

set和dict的唯一区别仅在于没有存储对应的value,但是,set的原理和dict一样,所以,同样不可以放入可变对象,因为无法判断两个可变对象是否相等,也就无法保证set内部“不会有重复元素”。

总结:

主要是一些基础的语法的学习,很多很Java的逻辑是差不多的,主要是python的自己的一些规则需要区分。

最近在家也不能出门,没事看看python相关语法。

参考文献:https://www.liaoxuefeng.com/wiki/1016959663602400/1017104324028448

个人知乎:https://www.zhihu.com/people/fu-wei-43-69/columns

个人:https://www.jianshu.com/u/bf0e38a8d400

你可能感兴趣的:(2020-01-29 python学习记录(1)-基础语法)