day02 python基础

python

 

一 列表
1 定义: 在[]内,可以存放多个任意类型的值,并以逗号隔开。
     一般用于存放学生的爱好,课堂的周期等等...

#定义一个学生列表,可存放多个学生

#list([\'dhevvs\', \'efdsa\', \'thjff\', \'trsv\'])

students = [\'dhevvs\', \'efdsa\', \'thjff\', \'trsv\']

print(students[1]) # efdsa

student_info = [\'er\', 84, \'male\', [\'泡8\', \'喝9\']]

# 取er同学的所有爱好

print(student_info[3])

# 取er同学的第二个爱好

print(student_info[3][1])

2 优先掌握的操作:

# 1、按索引存取值(正向存取+反向存取):即可存也可以取

print(student_info[-2]) # male

# 2、切片(顾头不顾尾,步长)

print(student_info[0:4:2]) # [\'er\', \'male\']

# 3、长度

print(len(student_info)) # 4

# 4、成员运算in和not in

print(\'er\' in student_info) # True

print(\'er\' not in student_info) # False

# 5、追加

student_info = [\'er\', 84, \'male\', [\'泡8\', \'喝9\']]

# 在student_info列表末尾追加一个值

student_info.append(\'xixi\')

print(student_info)

# 6、删除

# 删除列表中索引为2的值

del student_info[2]

print(student_info)

# 7、循环

for student in student_info:

print(student)

 3 需要掌握的操作:

 student_info = [\'killer\', 95, \'female\', [\'gawu\', \'hanmai\'], 95]

# 1.index 获取列表中某个值的索引

print(student_info.index(95)) # 1

# 2.count 获取列表中某个值的数量

print(student_info.count(95)) # 2

# 3.取值,默认取列表中最后一个值,类似删除

# 若pop()括号中写了索引,则取索引对应的值

student_info.pop()

print(student_info)

# 取出列表中索引为2的值,并赋值给sex变量名

sex = student_info.pop(2)

print(sex)

print(student_info)

student_info = [\'miller\', 95, \'female\', [\'xx\', \'hh\'], 95]

# 4.移除,把列表中的某个值的第一个值移除

student_info.remove(95)

print(student_info) # [\'miller\', \'female\', [\'xx\', \'hjh\'], 95]

name = student_info.remove(\'miller\')

print(name) # None

print(student_info) # [\'female\', [\'xx\', \'hh\'], 95]

# 5.插入值

student_info = [\'jun\', 95, \'female\', [\'xx\', \'hh\'], 95]

# 在student_info中,索引为3的位置插入“合肥学院”

student_info.insert(3, \'合肥学院\')

# print(student_info)

# 6.extend 合并列表

student_info1 = [\'jun\', 95, \'female\', [\'xx\', \'hh\'], 95]

student_info2 = [\'miller\', 95, \'female\', [\'xx\', \'hh\'], 95]

# 把student_info2所有的值插入student_info1内

student_info1.extend(student_info2)

print(student_info1)

二 元组数据类型

1 定义:

#  tuple((1, 2, 3, \'五\', \'六\'))

tuple1 = (1, 2, 3, \'五\', \'六\')

print(tuple1) # (1, 2, 3, \'五\', \'六\')

2 优先掌握的操作:

# 1、按索引取值(正向取+反向取):只能取

print(tuple1[2]) # 3

# 2、切片(顾头不顾尾,步长)

# 从0开始切片到5-1, 步长为3

print(tuple1[0:5:3]) # (1, \'五\')

# 3、长度

print(len(tuple1)) # 5

# 4、成员运算in和not in

print(1 in tuple1) # True

print(1 not in tuple1) # False

# 5、循环

for line in tuple1:

# print(line)

# print默认end参数是\n

print(line, end=\'_\')

三 可变数据类型和不可变数据类型
1 不可变类型:
    变量的值修改后,内存地址一定不一样。
     数字类型
        int
        float
     字符串类型
         str
     元组类型
        tuple
2 可变类型:
     列表类型
        list    
     字典类型

         dict
3 举例说明

#不可变类型

# int

number = 100

print(id(number)) # 1434810944

number = 111

print(id(number)) # 1434811296

# float

sal = 1.0

print(id(sal)) # 2771339842064

sal = 2.0

print(id(sal)) # 2771339841896

str1 = \'hello python!\'

print(id(str1)) # 1975751484528

str2 = str1.replace(\'hello\', \'like\')

print(id(str2)) # 1975751484400

# 可变类型:

# 列表

list1 = [1, 2, 3]

list2 = list1

list1.append(4)

# list1与list2指向的是同一份内存地址

print(id(list1)) # 2090131662408

print(id(list2)) # 2090131662408

print(list1) # [1, 2, 3, 4]

print(list2) # [1, 2, 3, 4]

四 字典类型
1 作用:
    在{}内,以逗号隔开可存放多个值,以key-value存取,取值速度快。

2 定义:
    key必须是不可变类型,value可以是任意类型

 dict1 = dict({\'age\': 26, \'name\': \'monika\'})

dict1 = {\'age\': 26, \'name\': \'monika\'}

print(dict1) # {\'age\': 26, \'name\': \'monika\'}

print(type(dict1)) # <class \'dict\'>

#取值,字典名 + [],括号内写值对应的key

print(dict1[\'age\'])

 3 优先掌握的操作:

 #1、按key存取值:可存可取

#存一个 level: 0的值到dict1字典中

dict1[\'level\'] = 0

print(dict1) # {\'age\': 26, \'name\': \'tank\', \'level\': 0}

print(dict1[\'name\']) # moniks

# 2、长度len

print(len(dict1))

# 3、成员运算in和not in 只判断字典中的key

print(\'name\' in dict1) # True

print(\'monika\' in dict1) # False

print(\'monika\' not in dict1) # True

# 4、删除

del dict1[\'level\']

print(dict1) # {\'age\': 26, \'name\': \'monika\'}

# 5、键keys(),值values(),键值对items()

# 得到字典中所有key

print(dict1.keys())

# 得到字典中所有值values

print(dict1.values())

# 得到字典中所有items

print(dict1.items())

#6、循环

#循环遍历字典中所有的key

for key in dict1:

print(key)

print(dict1[key])

# get

dict1 = {\'age\': 18, \'name\': \'monika\'}

print(dict1.get(\'age\'))# 18

# []取值print(dict1[\'sex\']) # KeyError: \'sex\'

# get取值

print(dict1.get(\'sex\')) # None

# 若找不到sex,为其设置一个默认值

print(dict1.get(\'sex\', \'male\'))

五 流程控制

1 if 判断:
    语法:
        if 判断条件:
            # 若条件成立,则执行此处代码
            逻辑代码
        elif 判断条件:
            # 若条件成立,则执行此处代码
            逻辑代码
        else:
            # 若以上判断都不成立,则执行此处代码
            逻辑代码

# 判断两数大小

x = 10

y = 20

z = 30

# 缩进快捷键,tab往右移动四个空格,shift + tab 往左移动四个空格

if x > y:

print(x)

elif z > y:

print(z)

else:

print(y)

2 while循环
    语法:
        while 条件判断:
            # 成立执行此处代码
            逻辑代码
            
break  # 跳出本层循环
continue  # 结束本次循环,进入下一次循环

str1 = \'monika\'

# while循环

while True:

name = input(\'请输入猜测的字符: \').strip()

if name == \'monika\':

print(\'tank success!\')

break

print(\'请重新输入! \')

# 限制循环次数

str1 = monika\'

# 初始值

num = 0 # 0 1 2 3

# while循环

while num < 3:

name = input(\'请输入猜测的字符: \').strip()

if name == \'monika\':

print(\'tank success!\')

break

print(\'请重新输入!\')

num += 1

六 文件处理
1、 open() # 打开文件
    写文件
        wt: 写文本
    读文件
        rt: 读文本
    追加写文件
        at: 追加文本   
注意: 必须指定字符编码,以什么方式写就得以什么方式打开。 如: utf-8
    
2、执行python文件的过程:
    1.先启动python解释器,加载到内存中。
    2.把写好的python文件加载到解释器中。
    3.检测python语法,执行代码。
    SyntaxError: 语法错误!

打开文件会产生两种资源:
    1.python程序
    2.操作系统打开文件

3、写文本文件
 参数一: 文件的绝对路径
 参数二: mode 操作文件的模式
 参数三: encoding 指定的字符编码

 f = open(\'file.txt\', mode=\'wt\', encoding=\'utf-8\')

f.write(\'Hello\')

f.close() # 关闭操作系统文件资源

4、读文本文件  r == rt

f = open(\'file.txt\', \'r\', encoding=\'utf-8\')

print(f.read())

f.close()

5、追加写文本文件

a = open(\'file.txt\', \'a\', encoding=\'utf-8\')

a.write(\'\n 合肥学院\')

a.close()

七 文件处理之上下文管理
with open() as f "句柄"

# 写

with open(\'file1.txt\', \'w\', encoding=\'utf-8\') as f:

f.write(\'墨菲定律\')

# 读

with open(\'file1.txt\', \'r\', encoding=\'utf-8\') as f:

res = f.read()

print(res)

# 追加

with open(\'file1.txt\', \'a\', encoding=\'utf-8\') as f:

f.write(\'围城\')

# f.close()

八 对图片、音频、视频读写
rb模式,读取二进制,不需要指定字符编码

# 读取相片cxk.jpg

with open(\'cxk.jpg\', \'rb\') as f:

res = f.read()

print(res)

jpg = res

# 把cxk.jpg的二进制流写入cxk_copy.jpg文件中

with open(\'cxk_copy1.jpg\', \'wb\') as f_w:

f_w.write(jpg)

with 管理多个文件

# 通过with来管理open打开的两个文件句柄f_r,f_w

with open(\'cxk.jpg\', \'rb\') as f_r, open(\'cxk_copy2.jpg\', \'wb\') as f_w:

# 通过f_r句柄把图片的二进制流读取出来

res = f_r.read()

# 通过f_w句柄把图片的二进制流写入cxk_copy.jpg文件中

f_w.write(res)

九 函数基础
1、函数定义形式

def 函数名(参数1, 参数2...):
    """注释: 声明函数"""
    逻辑代码
    return 返回值


注意:
def: defind 定义。
函数名: 必须看其名知其意。
(): 接收外部传入的参数。
注释: 用来声明函数的作用。
return: 返回给调用者的值。

定义函数的三种形式:
    1.无参函数
        不需要接收外部传入的参数。
    2.有参函数
        需要接收外部传入的参数。  
    3.空函数
        pass
        
2、函数调用:
    函数名 + () 调用

3、无参函数

def login():

user = input(\'请输入用户名\').strip()

pwd = input(\'请输入密码\').strip()

if user == \'monika\' and pwd == \'123\':

print(\'login successful!\')

else:

print(\'login error!\')

# 函数的内存地址

print(login)

# 函数调用

login()

4、有参函数

# username,password 用来接收外部传入的值

def login(username, password):

user = input(\'请输入用户名\').strip()

pwd = input(\'请输入密码\').strip()

if user == username and pwd == password:

print(\'login successful!\')

else:

print(\'login error!\')

# 函数调用

# 若函数在定义时需要接收参数,调用者必须为其穿传参

login(\'monika\', \'123\')

5、空函数
ATM:
    1.登录
    2.注册
    3.提现
    4.取款
    5.转账
    6.还款

# 登录功能

def login():

# 代表什么都不做

pass

# 注册功能

def register():

# 代表什么都不做

pass

# 还款功能

def repay():

pass

6、函数的参数:

# 在定义阶段: x, y称之为形参。

def func(x, y): # x, y

print(x, y)

# # 在调用阶段: 10, 100 称之为实参。

func(10, 100)

# 位置参数:

# 位置形参

# 位置实参

# 必须按照位置一一传参。

# 在定义阶段: 位置形参

def func(x, y): # x, y

print(x, y)

# 在调用阶段: 10, 100 称位置实参。

func(10, 100) # 10 100

# 关键字参数:

# 关键字实参

# 按照关键字传参。

# 位置形参x, y

def func(x, y):

print(x, y)

# 在调用阶段: x=10, y=100称之为关键字参数。

func(y=111, x=10) # 10 111

# 不能少传

func(y=111) # 报错TypeError

# 不能多传

func(y=111, x=222, z=\'333\') # 报错TypeError

# 默认参数:

# 在定义阶段,为参数设置默认值

def foo(x=10, y=20):

print(x, y)

# 不传参,则使用默认参数

foo()

# 传参,使用传入的参数

foo(200, 300)

7、函数的嵌套定义:
    在函数内部定义函数。
8、函数对象:
    函数的内存地址称之为函数对象。
9、函数的名称空间:
    内置:
        python解析器自带的都称之为"内置名称空间"。
    全局:
        所有顶着头写的变量、函数...都称之为"全名称空间"。
    局部:
        在函数内部定义的,都称之为"局部名称空间"。
    名称空间加载顺序:
        内置 ---> 全局 ---> 局部
    名称空间查找顺序:  
        局部 ---> 全局 ---> 内置

# 函数的嵌套定义

def func1():

print(\'from func1...\')

def func2():

print(\'from func2...\')

# 函数对象

print(func1)

def f1():

pass

def f2():

pass

dic1 = {\'1\': f1, \'2\': f2}

choice = input(\'请选择功能编号: \')

if choice == \'1\':

print(dic1[choice])

dic1[choice]()

elif choice == \'2\':

print(dic1[choice])

dic1[choice]()

# 名称空间

# 函数的嵌套定义

def func1():

# x = 20

print(\'from func1...\')

print(x) # 报错

x = 30

def func2():

print(\'from func2...\')

func1()

 

以上是 day02 python基础 的全部内容, 来源链接: utcz.com/z/386817.html

回到顶部