day02 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()

 

转载于:https://www.cnblogs.com/decades/p/11087404.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值