Python总结2
'''
列表
定义:在[]内,可以存放多个任意类型的值,并以逗号隔开
''''
students=['sb','2b']
print(students[1])
student_info=['ming',18,'male,['泡吧’,‘喝酒’]]
print(student_info[3][1])
print(student_info[0,4,2])
长度
print(len(student_info))
追加
student_info.append('打飞机')
删除
del student_info[2]
索引
print(student_info.index(18))
count 获取列表中某个值的数量
print(student_info.count(18))
取值,默认取列表中最后一个值,类似于删除
pop()内有了索引获取列表对应的索引
student_info.pop()
删除remove
student_info.remove[18]#把列表中第一个索引值删掉
插入值insert()
student_info.insert(3,'合肥学院’)
#合并列表
student_info1=['ming',18,'male,['泡吧’,‘喝酒’]]
student_info2=['阿郎',18,'male,['泡吧’,‘打飞机’]]
student_info1.extend(student_info2)
定义:在()内,可以存放多个任意类型的值,并以逗号隔开。注意:元组与列表不一样的是,只能在定义时初始化值,不能对其进行修改。
优点:在内存中占用资源较少
tuplel=(1,2,3,'wu')
#1按索引取值
print(tuplel[2])
#2切片
print(tuplel[0:5:3])
#3长度
#4成员运算
#5循环
for line in tuplel:
print(line,end'_')
作用:在{}内,存多个值,key-value存取,取值速度快
定义:key必须是不可变类型,value可以是任意类型
不可变类型:
'''
变量的值修改后,内存地址一定不一样
数字类型 int,float
字符串类型 str
元组类型tuple
可变类型:
列表类型 list
字典类型 dict
#int
number = 100
print(id(number))
number = 111
#可变类型内存地址一样
列表
list1=[1,2,3]
list2=list1
list1.append(4)
print(id(list1))
print(id(list2))
print(id(number))#两者id不一样
'''
dict1=dict({'age':18,'name':'ming'})
取值:字典名+[];[]内写值对应的key
print(dict1[age])
#1按key存取值
#存一个level:9的值到dict1字典中
dict1['level']=9
成员运算值判断字典中的key
删除
del dict1['level']
print(dict1.keys())
#循环
for key in dict1
print(key)
print(dict1[key])
#get
print(dict1.get('age'))
#[]取值
print(dict1['sex'])
#get
print(dict1.get('sex','male))
语法:
if判断条件:
elif 判断条件:
else:
语法:
while 条件判断:
#成立执行此处代码
break#跳出本层循环
continue #进行下一次循环
注意必须指定字符编码以什么方式写就得以什么方式打开
执行python代码过程,1先启动python解释器,2把写好的python文件加载到内存中,3检测python语法执行代码
打开文件会产生两种资源;
1python程序
2操作系统打开文件
#参数一:文件的绝对路径
#参数二:操作文件的模式
#参数三:encoding指定的字符编码
#写文本
f=open('file.txt',mode=wt,encoding='utf-8')
f.write('ming')
f.close()#关闭操作系统打开的文件
#读文本
f.open('file.txt','r',encoding='utf-8')
print(f.read())
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',‘r’,encoding='utf-8')as f:
res = f.read()
print(res)
rb模式读取二进制不需要指定字符编码
with open.('cxk.jpg',‘rb’)as f:
res=f.read()
print(res)
jpg=res
#把cxk.jpg的二进制流写入cx_copy.jpg文件中
with open('cxk_copy.jpg','wb')as f_w:
f_w.write(jpg)
#通过f_r句柄把图片的二进制读取出来
res = f_r.read()
#通过f_w句柄把图片的二进制流写入cxk_copy.jpg中
f_w.write(res)
#with可以管理多个文件
函数其实是一种工具
使用函数的好处:
1.解决代码冗余问题
2.代码的结构跟清晰
3.易管理
函数必须先定义,后调用
函数定义语法:
def 函数名(参数1,参数2...):
'''注释:声明函数'''
逻辑代码
return 返回值
def:defind 定义。
函数名:必须看起名知其意
():接收外部传入的参数
注释:用来声明函数的作用
return:返回调用者的值
定义的三种形式
1.无参函数
不需要接收外部的参数
def login():
user=input('请输入用户名’).strip()
pwd=input('请输入密码').strip()
if user == 'ming' and pwd == '123':
print('successful')
print('arror')
#函数的内存地址
print(login)
login()
def login(username,password):
user=input('请输入用户名’).strip()
pwd=input('请输入密码').strip()
if user == username and pwd ==password:
print('successful')
print('arror')
login('ming','123')
3.空函数
pass
函数的参数:
'''
#在定义阶段x,y称为形式参数
def func(x,y):
print(x,y)
#在调用阶段:10,100称之为实参
fuc(10,100)
位置参数
'''
在定义阶段:位置形参
def func(x,y):
print(x,y)
在调用阶段:10,100位置实参
fuc(10,100)
'''
关键字参数:
关键字实参
#在调用阶段:x=10,y=100称为关键字参数
#不能少传也不能多传
fuc(x=10,y=100)
'''
默认参数
'''
def foo(x=10,y=20)
print(x,y)
#不传参数则使用默认参数
foo()
#传参数,使用传入的参数
foo(200,300)
#函数的嵌套定义
函数的名称空间:
内置:
python解释器自带的都称为”内置名称空间“。
全局:
所有顶着头写的变量,函数...都称为“全局名称空间”。
局部:
在函数内部定义的,都称为“局部名称空间”。
名称空间加载顺序:
内置——全局——局部
名称空间的访问顺序:
局部——全局——内置
def func1():
print('from func1...')
def func2():
print("from fuc2...')
#函数定义
print(func1)
def f1():
pass
def f2():
pass
dic1 = {'1':f1,'2':f2}
if choice =='1':
print(dic1[choice])
dic1[choice]()
elof choice == '2':
print(dic1[choice])
dic1[choice]()
Python总结2的更多相关文章
- Python中的多进程与多线程(一)
一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...
- Python高手之路【六】python基础之字符串格式化
Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议
软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...
- 可爱的豆子——使用Beans思想让Python代码更易维护
title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...
- 使用Python保存屏幕截图(不使用PIL)
起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...
- Python编码记录
字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...
- Apache执行Python脚本
由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...
- python开发编译器
引言 最近刚刚用python写完了一个解析protobuf文件的简单编译器,深感ply实现词法分析和语法分析的简洁方便.乘着余热未过,头脑清醒,记下一点总结和心得,方便各位pythoner参考使用. ...
- 关于解决python线上问题的几种有效技术
工作后好久没上博客园了,虽然不是很忙,但也没学生时代闲了.今天上博客园,发现好多的文章都是年终总结,想想是不是自己也应该总结下,不过现在还没想好,等想好了再写吧.今天写写自己在工作后用到的技术干货,争 ...
随机推荐
- Neutron中的网络I/O虚拟化
为了提升网络I/O性能.虚拟化的网络I/O模型也在不断的演化: 1,全虚拟化网卡(emulation).如VMware中的E1000用来仿真intel 82545千兆网卡,它的功能更完备,如相比一些半 ...
- 小胖说事31------iOS 真机编译错误"“XXX”的 iPod" and run "XXX" again, or if "XXX" is still running
在真机上測试时用一会就出现例如以下信息,且应用挂掉. Restore the connection to ""XXX"的 iPod" and run " ...
- unable to execute dex: multiple dex files Cocos2dxAccelerometer
原文转载:http://discuss.cocos2d-x.org/t/conversion-to-dalvik-format-failed-unable-to-execute-dex-multipl ...
- C++中的继承与虚函数各种概念
虚继承与一般继承 虚继承和一般的继承不同,一般的继承,在目前大多数的C++编译器实现的对象模型中,派生类对象会直接包含基类对象的字段.而虚继承的情况,派生类对象不会直接包含基类对象的字段,而是通过一个 ...
- CoffeeScript里的or
CoffeeScript里的or,其实会被编译为 || 这并没有什么令人惊奇之处.我惊讶的是类似这样一个表达式: word = null hi = word or "Hello World! ...
- Kubernetes——基于容器技术的分布式架构领先方案,它的目标是管理跨多个主机的容器,提供基本的部署,维护以及运用伸缩
1.Kubernetes介绍 1.1 简介 Kubernetes是什么?首先,它是一个全新的基于容器技术的分布式架构领先方案.其次,它是一个开放的开发平台.最后,它是一个完备的分布式系统支撑平台.Ku ...
- c#用webkit内核支持html5
[实例简介]经过测试可用 [实例截图] [核心代码] 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 using System; ...
- 第二周 Leetcode 493. Reverse Pairs(HARD)
leetcode 493跟经典的逆序对问题没有什么区别, 首先考虑对数组前半部和后半部求逆序对数,若能保证两段数组都有序,则显然可以在线性时间内求出对数. 所以我们采用归并排序的方法,一方面让数组有序 ...
- jqxtree异步加载部门树
整体思路 A.要想实现异步加载第一次加载的是一级部门 B.加载一级部门,如果有子部门,部门前面带+号,没有子部门,部门前面没有+号(+号也就是点击可以展开) C.在sql中实现如果有子部门默认都加载一 ...
- github 用户不被识别问题
期末考完,继续开发. 用过的都知道,直接用的话贡献者上面显示不出自己. 查一下就知道是因为github的识别是靠邮箱设置的. 但是如果频繁创建新仓库,容易忘记设定用户名和邮箱. 突发奇想,发现 ...