Python基础学习

一、数据类型和变量

1、整数

Python可以处理任意大小的整数,负整数。例如:0,100,-100等

对于很大的数,可以用“_”来分隔0,用以清楚阅读0的个数。例如:10_000_000和10000000完全一样。

十六进制用0x前缀和0-9,a-f表示。例如:0xffff等

2、浮点型

浮点型 = 小数,小的浮点数可以用数学法,例如1.2,3.1415926等。大的浮点必须用科学计数法表示,把10用e代替,1.23x10^9就是1.23e9或者12.3e8 。

3、字符串

用‘单引号或者“双引号引起来的任意文本。例如:’abc‘,”abc“等。

如果字符串中还包含’或者”,可以用转义字符 \ 来标识。例如:“I\'m \"OK\"!",就等于I'm "OK"!

转义字符有很多,例如:

\n表示换行
\t表示制表符
\\表示字符\

4、布尔型

布尔值只有两种状态,True和False。可以进行 and(与),or(或),not(非)运算。

5、变量

变量可以是任意数据类型。

变量名必须是英文、数字和_的组合,且不能以数字开头。

二、list、tuple、dict、set

1、list

list是Python内置的一种列表,list是一钟有序的集合,可以随时添加和删除数据。

list中的元素数据类型不用必须相同。

比如:列出周一、周二、周三……

week = ['Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sunday']

变量week就是一个list,用 len() 函数可以获取list元素的个数。

len()week[0]可以访问list的第一个元素(ps:下标从0开始),同理week[1]可以访问第二个元素。

week[-1]可以访问倒数第一个元素,同理week[-2]可以访问倒数第二个元素。

注意不要越界,越界会报错。

append

week.append('***'),此语句可以将***插入到week末尾。

pop

week.pop(),此语句可以删除week末尾的元素。

week.pop(i),此语句可以删除week指定索引位置的元素。

替换元素

可直接用 = 赋值。例如week[0] = "周一",这样就将“Monday”替换为“周一”。

index

week.index("Monday"),可以查找Monday元素的角标,并返回数值。

表中表

list元素可以是list。

2、tuple

tuple和list十分相似,但是tuple元素用()括起来,list用 [ ] 括起来,且tuple定义之后不可变。

tuple注意的两点:1、可以定义tuple为空,例 t = ();

2、如果tuple只有一个元素,元素后面要加“,”,目的是与()运算符区分,例 t = ( 1 , )。

3、dict

dict是Python内置的字典,就相当于其它语言的map,使用“键-值”存储,查找速度快。

例如,存储班级里面人名和成绩,普通方式可以用两个list分别存储name和source,但是这样占用空间大,操作麻烦,且list是顺序查找,时间长。

names = ['张三', '李四', '王五']
scores = [95, 85, 75]

但是使用dict就可以解决此问题,例如:

d = {'张三': 95, '李四': 85, '王五': 75}

此时变量d就是定义的dict,同时存下了姓名和成绩。

若要查找张三的成绩,直接 d["张三"] ,就可以返回张三的成绩。

 一个key只对应一个value,若多次对一个key赋值,那就会覆盖掉之前的value。

要是找的key不存在,会报错,可以使用 “in”,或者 “get()” 看看key是否在dict中。

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

  1. 查找和插入的速度极快,不会随着key的增加而变慢;
  2. 需要占用大量的内存,内存浪费多。

而list相反:

  1. 查找和插入的时间随着元素的增加而增加;
  2. 占用空间小,浪费内存很少。

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

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

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

4、set

set与dict类似,也是key的集合,但不存储value。且key不能重复,

>>> s = set([1, 2, 3])
>>> s
{1, 2, 3}

add

通过 add(key) 方法可以添加元素到set中,虽然可以添加重复的key,但并不会起效。

remove

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

 三、条件判断

条件判断关键词有三个if,elif,else,使用的时候语句后面不要忘记加:冒号,且要注意换行和缩进。

如果if不成立,就执行elif,如果还不成立,就else。

例题:计算BMI(体重KG除以身高M的平方),并根据BMI指数判断。

  • 低于18.5:过轻
  • 18.5-25:正常
  • 25-28:过重
  • 28-32:肥胖
  • 高于32:严重肥胖

代码如下:

height = float(input("Enter your height:  M"))
weight = float(input("Enter your weight: KG"))

bmi = weight / (height * height)
print("Your BMI is ",bmi)
if bmi>= 0  and bmi < 18.5:
    print("过轻")
elif bmi >= 18.8 and bmi< 25:
    print("正常")
elif bmi >= 25 and bmi < 28:
    print("过重")
elif bmi >= 28 and bmi < 32:
    print("肥胖")
elif bmi >= 32:
    print("严重肥胖")
else:
    print("输入错误")

 此处注意input,Python读入的都是str类型的,如果要进行计算,首先要进行格式转换。

四、循环

循环有for和while

1、for……in

for……in循环可以把list的每个元素依次迭出来,也可以把变量带入实数。

names = ["你","好","呀",6,6,6]
s = 0
for i in range(10):
    if i != 9:
        print(i,end=' + ')
    else:
        print(i,end='')
    s = s + i
print(" =", s)

for name in names:
    print(name,end='')
print()

s = 0
for i in [1,2,3,4,5]:
    if i != 5:
        print(i,end=' + ')
    else:
        print(i,end='')
    s = s + i
print(" =", s)

运行结果

2、while

while就是只要条件满足,就一直循环。

例如计算0到100累加:

n = 0
s = 0
while n <= 100:
    s = s + n
    n = n + 1
print(s)

 


———————————————————————————————————

以上为学习笔记。 

posted @ 2021-06-20 21:25  Cool-baby  阅读(62)  评论(0编辑  收藏  举报