一、数据类型

列表:

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

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

students = ['A','B','C','D']
print(students[1]) #B
student_info = ['S',84,'male',['泡8','喝9']]
#取S同学的所有爱好
print(student_info[3])
#取S同学的第二个爱好
print(student_info[3][1])

优先掌握的操作: 

1、按索引存取值(正向存取+反向存取):即可存也可以取
print(student_info[-2]) #S 2、切片(顾头不顾尾,步长)
print(student_info[0:4:2]) #['S','male'] 3、长度
print(len(student_info)) #4 4、成员运算in和not in
print('S' in student_info) #Ture
print('S' not in student_info) #False 5、追加
student_info = ['S',84,'male',['泡8','喝9']]
#在student_info列表末尾追加一个值
student_info.append('合肥学院')
print(student_info) 6、删除 删除列表中索引为2的值
del student_info[2]
print(student_info) 7、循环
for student in student_info:
print(student)

 需要掌握的操作:

student_info = ['S',95,'female',['尬舞','喊麦'],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) 4、移除,把列表中的某个值的第一个值移除
student_info.remove(95)
print(student_info) #['S','female',['尬舞','喊麦'],95]
name = student_info.remove('S')
print(name) #None
print(student_info) #[95,'female',['尬舞','喊麦'],95] 5、插入值
student_info.insert(3,'合肥学院')
print(student_info) 6、extend 合并列表
student_info1 = ['S',95,'female',['尬舞1','喊麦2'],95]
student_info2 = ['K',94,'female',['尬舞1','喊麦2']]
#把student_info2所有的值插入student_info1内
student_info1.extend(student_info2)
print(student_info1)

元组:

定义:定义:在()内,可以存放多个任意类型的值,并以逗号隔开

注意:元组与列表不一样的是,只能在定义时初始化值,不能对其进行修改。

优点:在内存中占用的资源比列表要小

定义:

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

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

print(tuple1)

优先掌握的操作:

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='_')

字典;

作用:

在{}内,以逗号隔开可存放多个值;以key-value存取,取值速度快

定义:

key必须是不可变类型,value可以是任意类型

#dic1 = dict({'age':18,'name':'lml'})
dict1 = {'age':18,'name':'lml'}
print(dict1) #{'age':18,'name':'lml'}
print(type(dict1)) #<class 'dict'> #取值,字典名+[],括号内写值对应的key
print(dict1['age']) #18

优先掌握的操作:

1、按key存取值:可存可取
#存一个level:9的值到dict1字典中
dict1['level'] = 9
print(dict1) #{'age': 18, 'name': 'lml', 'level': 9}
print(dict1['name']) #lml 2、长度len 3、成员运算in和not in 只判断字典中的key
print('name' in dict1) #True
print('lml' in dict1) #False
print('lml' not in dict1) #True 4、删除
del dict1['level']
print(dict1) #{'age': 18, 'name': 'lml'} 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:

#get
dict1 = {'age':18,'name':'lml'}
# print(dict1,get('age'))
#取值
# print(dict1['sex']) #KeyError: 'sex'
#get取值
print(dict1.get('sex')) #None
#若找不到sex,为其设置一个默认值
print(dict1.get('sex','male'))  

二、流程控制

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)

while:

语法:
         while 条件判断:
         # 成立执行此处
         逻辑代码

break # 跳出本层循环
         continue # 结束本次循环,进入下一次循环

str1 = 'lml'
# while循环
while True:
name = input('请输入猜测的字符:').strip()
if name == 'lml':
print('lml success!')
break;
print('请重新输入!')
# 限制循环次数
str1 = 'lml'
# 初始值
num = 0 # 0 1 2 3
# while循环
while num < 3:
name = input('请输入猜测的字符:').strip()
if name == 'lml':
print('lml success!')
break
print('请重新输入!')
num += 1  

三、文件处理

open()

wt: 写文本
读文件
rt: 读文本
追加写文件
at: 追加文本
注意: 必须指定字符编码,以什么方式写,就得以什么方式打开。 如: utf-8

执行python文件的过程:
    1.先启动python解释器,加载到内存中。
    2.把写好的python文件加载到解释器中。
    3.检测python语法,执行代码。
    SyntaxError: 语法错误!

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

f = open('file.txt', mode='wt', encoding='utf-8')
f.write('lml')
f.close() # 关闭操作系统文件资源
# 追加写文本文件
a = open('file.txt', 'a', encoding='utf-8')
a.write('\n合肥学院')
a.close()

文件处理之上下文管理

with可以管理open打开的文件,会在with执行完毕后自动调用close()关闭文件

with open()as f "句柄"


with open('file.txt', 'w', encoding='utf-8') as f:
f.write('墨菲定律')

with open('file.txt', 'r', encoding='utf-8') as f:
res = f.read()
print(res)
追加
with open('file.txt', 'a', encoding='utf-8') as f:
f.write('围城')
# f.close()

对图片、音频、视频等读写

# 读取相片cxk.jpg
with open('cxk.jpg', 'rb') as f:
res = f.read()
print(res)
jpg = res
# 把cxk.jpg的二进制流写入cxk_copy.jpg文件中
with open('cxk.copy.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_copy.jpg', 'wb') as f_w:
# 通过f_r句柄把图片的二进制流读取出来
res = f_r.read()
# 通过f_w句柄把图片的二进制流写入xck_copy.jpg文件中
f_w.write(res)

四、函数

函数:

    函数其实是一种工具
使用好处:1、解决代码冗余问题。
2、使代码的结构更清晰
3、易管理
函数的使用必须遵循:先定义再调用
定义:
def 函数名(参数1,参数2...):
# 注释:声明函数
逻辑代码
return 返回值 def:defind 定义。
函数名:必须看其名知其意。
():接收外部传入的参数
注释:;用来声明函数的作用。
return:返回给调用者的值
定义函数的三种形式:
1、无参函数 不需要接收外部传入的参数
2、有参函数 需要接收外部传入的参数
3、空函数 pass
1、无参函数
def login():
user = input('请输入用户名').strip()
pwd = input('请输入密码').strip() if user == 'lml' and pwd == '123':
print('login successful!')
else:
print('login error!')
# 函数的内存地址
print(login)
# 函数调用
login() 2、有参函数
# 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!') 3、空函数
'''
ATM:
1、登录
2、注册
3、提现
4、取款
5、转账
6、还款
'''
# 登录功能
def login():
# 代表什么都不做
pass
# 注册功能
def register():
# 代表什么都不做
pass
# 还款功能
def repay():
pass
参数的参数:
# 在定义阶段: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=10,z='333') #报错TypeError

 默认参数

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

def foo(x=10,y=20):
print(x,y)
#不传参,则使用默认参数
foo()
#传参,使用传入的参数
foo(200,300)
函数的嵌套定义:
在函数内部定义函数
函数对象:
函数的内存地址称之为函数对象
函数的名称空间:
内置: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]() x = 10
名称空间
函数的嵌套定义
def func1():
#x = 20
print('from func1...')
print(x) #报错:代码是由上自下执行,print(x)无法引用x = 30,所以报错
x = 30
def func2():
print('from func2...')
func1()
 
 
 

实训day02 python的更多相关文章

  1. 实训day01 python基础

    一.编程语言 编程语言:可以被计算机所识别的表达方式. 编程:程序员通过编程语言将自己的想法编写出来,产生的结果就是包含字符的文件. 其中,只有程序在运行时,其中的字符才有特定的语法意义. 二.计算机 ...

  2. <实训|第五天>通过搭建NFS,FTP实现共享文件附Vim脚本游戏

    先说个事情:我周末是不更新这个系列教程的,不过其他内容的会更新,我周末就整理这一周的各种内容到我的微信公众号中,提供给大家! 期待已久的linux运维.oracle"培训班"终于开 ...

  3. 实训三(cocos2dx 3.x 打包apk)

    上一篇文章<实训二(cocos2dx 2.x 打包apk)>简单的讲述的利用cocos2dx 2.x引擎在windows平台上打包apk的方法与过程,本文将介绍3.x版本引擎,如何打包ap ...

  4. 实训一(cocos2d-x相关)

    实训内容简介: 大四开始前系里安排的的集中实践环节,根据要求,开发app应用软件. 目标app:Stick_mxj 目的:继续对cocos2d-x的学习,完成实践环节,解决现在对引擎不是很清楚的一些问 ...

  5. Java企业实训 - 01 - Java前奏

    前言: 虽然个人专攻.NET方向,不过由于个人是干教育行业的,方方面面的东西,不能说都必须精通,但肯定多少都会涉及到. 一个菜鸟学员,从啥都不会,经过一步步学习,最后到企业上手掌管一个模块甚至一个项目 ...

  6. UML基础与Rose建模实训教程

    目  录 第1章  初识UML. 1 1.1 初识UML用例图... 1 1.2 初识UML类图... 3 第2章  Rational Rose工具... 6 2.1 安装与配置Rational Ro ...

  7. <实训|第六天>偷偷让新手的Linux无限重启附linux主机名称不是随便乱改的!

    先说个事情:这几天我正在忙一个项目的设计,8月1号之前要弄出来,所以每天都要弄到很晚,可能更新就有点跟不上了,不过我如果有时间的话,我就更新,没时间的话,我会在8月1号之后统一更新出来,希望大家谅解! ...

  8. 软件工程实训项目案例--Android移动应用开发

    实训过程 角色分工 1.项目经理:负责项目的组织实施,制定项目计划,并进行跟踪管理 2.开发人员:对项目经理及项目负责 3.需求分析员:负责系统的需求获取和分析,并协助设计人员进行系统设计 4.系统设 ...

  9. <实训|第四天>Linux下的vim你真的掌握了吗?附上ftp远程命令上传。

    期待已久的linux运维.oracle"培训班"终于开班了,我从已经开始长期四个半月的linux运维.oracle培训,每天白天我会好好学习,晚上回来我会努力更新教程,包括今天学到 ...

随机推荐

  1. USACO 奶牛排队

    题目:给出一个只含有1,2,3的数字序列,问最少交换多少次才能将之变为递增数列. 解: 注意到只有1,2,3,我们只要将1,3交换到自己的应在位置上那么排序就已经完成了. 需要交换的有几种,记$a(x ...

  2. 018--python 函数参数、变量、前向引用、递归

    目录 一.python函数的定义 二.函数参数 三.全局变量和局部变量 四.前向引用 五.递归 一.python函数的定义 python函数是对程序逻辑进行结构化或过程化的一种方法 1 python中 ...

  3. Linux2.6 内核中结构体初始化(转载)

    转自:http://hnniyan123.blog.chinaunix.net/uid-29917301-id-4989879.html 在Linux2.6版本的内核中,我们经常可以看到下面的结构体的 ...

  4. rbenv的使用

    创建: 2017/09/05 更新: 2018/02/03 增加更新rbenv和获取list没有的版本 更新: 2018/02/25 把path里面[个人主机名]全部替换为[主机名] 更新: 2018 ...

  5. 51nod 1347 【水】

    #include<cstdio> #include <map> #include<iostream> #include<string.h> #inclu ...

  6. bzoj 5499: [2019省队联测]春节十二响【堆】

    首先看两条链怎么合并,贪心可得是从大到小取max,多条链同理 所以dfs合并子树的大根堆即可,注意为了保证复杂度,合并的时候要合并到最长链上,证明见长链剖分 #include<iostream& ...

  7. SQLite3初级使用

    (1)SQL的指令格式 所有的SQL指令都是以分号(;)结尾的.如果遇到两个减号(--)则代表注解,sqlite3会略过去. (2)建立资料表 假设我们要建一个名叫film的资料表,只要键入以下指令就 ...

  8. android 显示目录下图片

    知识点 1. 网格视图 2. 读取文件 MainAcitvity package com.test.gridview; import android.support.v7.app.AppCompatA ...

  9. 【bzoj2084】[Poi2010]Antisymmetry

    2084: [Poi2010]Antisymmetry Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 1205  Solved: 756[Submit ...

  10. 2017zstu新生赛

    1.b^3 - a^3 = c(zy) zy说要卡nlogn的,然而他实际给的组数只有100组,然后因为在windows下随机的,所以给出的 c <= 100000.然后只要胆子大.... 通过 ...