set集合:

•集合的创建;

set_1 = set() #方法一
set_1 = {''} #方法二

•set是无序,不重复的集合;

set_1 = {'k1','k2','k3'}
set_1.add('k1') #往集合set_1中添加元素
set_1 = {'k1','k2','k3'}

•set也可以直接将字典中的key给过滤出来放在集合中;

dic_1 = {'k1':1,'k2':2}
set_2 = set(a) #将字典a中的键放入集合b中
set_2 = {'k1','k2'}

•集合有如下的操作方法,add、clear、copy、difference、difference_update、discard、intersection、intersection_update、 union、update等

set_1 = {1,2,3,4}
set_2 = {2,3,4,5}
#add,集合中添加元素
set_1.add(5)
set_1 = {1,2,3,4,5}
#clear,清除集合的元素
set_1.clear()
set_1 = set()
#difference,找出两个集合中前一个独有的元素
set_3 = set_1.difference(set_2)
set_3 = {1}
#difference_update,找出两个集合中前一个独有的元素,并且重新赋值给第一个集合
set_1.difference_update(set_2)
set_1 = {1}
#discard,删除集合中的元素
set_1.discard(1)
set_1 = {2,3,4}
#intersection,找出两个集合中的共有元素
set_3 = set_1.intersection(set_2)
set_3 = {2,3,4}
#intersection.update,找出两个集合中的共有元素,并且重新赋值给第一个集合
set_1.intersection_update(set_2)
set_1 = {2,3,4}
#union,将两个集合合并成一个新的集合
set_3 = set_1.union(set_2)
set_3 = {1,2,3,4,5}
#update,更新第一个集合
set_1.update(set_2)
set_1 = {1,2,3,4,5}
#symmetric_difference,取出两个集合的差集
set_3 = set_1.symmetric_difference(set_2)
set_3 = {1,5}
#symmetric_difference_update,取出两个集合的差集,并且重新赋值给第一个集合
set_1.symmetric_difference_update(set_2)
set_1 = {1,5}
#issuperset,判断第一个集合是否为第二个集合的父集,返回True或者False
set_1 = {1,2,3}
set_2 = {2,3}
judge = set_1.issuperset(set_2)
judge = True
#issubset,判断第一个集合是否为第二个集合的子集,返回True或者False
set_1 = {1,2,3}
set_2 = {2,3}
judge = set_2.issubset(set_1)
judge = True
#isdisjoint,判断两个集合是否相交,相交返回False,否则True
set_1 = {1,2,3}
set_2 = {2,3,4}
set_3 = {4,5,6}
judge = set_1.isdisjoint(set_2)
judge = False
judge = set_1.isdisjoint(set_3)
judge = True

•注意:集合set中只能放str,int,tuple,不能放list,dict

函数部分:

•函数式编程和面向对象编程的区别:函数式编程将功能代码封装在函数中,进行其它代码的时候可以调用其功能,无序重复;面向对象对函数进行分类和封装,使其发挥更大的功能

•函数的定义

def main(参数): #def是定义函数的关键字,创建函数名为main的函数,
函数体
...
...
返回值

函数体不执行,只有当函数调用的时候函数体才会执行;

•函数中的参数说明

①普通参数,严格按照顺序,将实际参数赋值给形式参数;

②默认参数,必须放在形式参数列表的最后;

③指定参数,将实际参数赋值给指定的形式参数;

④动态参数,

*,默认将传入的参数全部放在tuple中;

**,全部放在字典中

动态参数*:形式参数前加*,表示可以添加n个参数,将这些参数放在一个tuple中;

形式参数和实数参数前面都加*,一个for循环,将每个元素转换到tuple里面;

形式参数前加**,传字典,用指定参数传值

形式参数和实数参数前面都加**,是一个直接的赋值

⑤万能参数,def fa(*a,**b),一定是*在前,**在后;

#普通参数,实参严格按照书序传递给形参
def send(name,age):
print(name,'is',age)
send('alex','31')
alex is 31 #输出
#默认参数,必须放在形参的末尾
def send(name,age,job='it',): #默认参数必须放在末尾,否则报错
print(name,'is',age,'job is',job)
send('alex','31')
alex is 31 job is it #输出
#指定参数,将实际参数赋值给形式参数
def send(name,age):
print(name,'is',age)
send(age=31,name='alex') #顺序无所谓,指定形参直接赋值
alex is 31 #输出
#动态参数
#第一种,传tuple
def send(*arg): #默认将传入的实参放在tuple中,可以传递n个实参
print(arg)
send('alex',31)
('alex',31) #输出
def send(*arg): #在形参和实参前面同事添加*,表示用for循环每个实参元素到tuple里面
print(arg)
send(*'alex',31,38)
('a','l','e','x',31,38) #输出
#第二种,传dict
def send(**arg): #默认将实参放在地点中,实参需要指定键和值
print(arg)
send(name='alex',age=31)
{'name':'alex','age':31} #输出
def send(**arg): #实参直接传一个字典给形参
print(arg)
dic = {'name':'alex','age':31}
send(**dic)
{'name':'alex','age':31} #输出
#万能参数
def send(*arg,**args): #一定是*在前,**再后
print(arg,args)
dic = {'name':'alex','age':31}
send(31,32,name = 'alex',age = 31)
(31, 32) {'age': 31, 'name': 'alex'} #输出

⑥str.format(*,**)格式化输出,参数传递的是tuple和dict

#第一种,传单个元素
msg = 'i am {0},age is {1}'.format('alex',31)
print(msg)
i am alex,age is 31 #输出
#第二种,传列表
msg = 'i am {0},age is {1}'.format(*['alex',31])
print(msg)
i am alex,age is 31 #输出
#第三种,传指定参数
msg = 'i am {name},age is {age}'.format(name='alex',age=31)
print(msg)
i am alex,age is 31 #输出
#第四种,传字典
msg='i am {name},age is {age}'.format(**{'name':'alex','age':31})
print(msg)
i am alex,age is 31 #输出

•内存回收机制,def f1();def f1()

def f1():
...
def f1():
...
f1() #调用f1函数时只会调用后一个

•注意:在函数传递的时候传递的是一个引用还是重新赋值?是引用!

•全局变量的把握

函数体自身的创建的变量只能自己用;函数体可以使用全局变量;所有作用域都可读,先读自己的,自己的没有再读全局的;

在函数局部中想要修改全局变量,global name,对name重新赋值

特殊:列表字典,可修改不可重新赋值,要重新赋值要用global

注意:定义全局变量一定要大写!

三目运算(三元运算):

对if,else的一个简写

#先判断if与else之间的条件是否成立,如果成立则if前面的表达式成立,不成立则else后面的表达式成立
name = 'alex' if 1 == 1 else 'sb'
print(name)

lambda表达式:只能用一行来表示

f2 = lambda a1: a1 + 100隐藏return

f2:函数名

a1:形参

剩余为函数体

def f1(a1):

  return a1 + 100

name = lambda user_name: print(user_name)
name('alex')
#输出
alex

lambda也是一种函数,对于简单的函数可用lambda来表示

•0,None,'',[],(),{}都是False

utf-8 一个汉字三个字节

gbk 一个汉字二个字节

字符串转换字节用bytes,encoding;表现形式是字节,底层是二进制

字节转化为字符串用str

文件操作

•文件操作一般经过如果两种步骤:

打开文件;操作文件

文件句柄 = open('文件路径','模式')

将文件句柄定义为f,当操作完成自己自动关闭

•文件的模式有如下几种

r:只读模式;

w:只写模式,每次会重写文件;

x:只写模式,不存在则创建,存在则报错;

a:追加模式,不存在则创建,存在则追加;

rb:表示对字节操作;

wb:表示对字节操作;

xb:表示对字节操作;

ab:表示对字节操作;

注意:当以字节方式打开文件时,你写入该文件的方式也应该是字节

•方便管理上下文的方法:,为了避免文件打开后忘记关闭;

with open('文件') as f:

  pass

seek始终以字节的方式去寻找

tell获取当前指针的位置

Python【集合】、【函数】、【三目运算】、【lambda】、【文件操作】的更多相关文章

  1. python中实现三目运算

    python中没有其他语言中的三元表达式,不过有类似的实现方法 如: a = 1 b =2 k = 3 if a>b else 4 上面的代码就是python中实现三目运算的一个小demo, 如 ...

  2. 【Python全栈笔记】03 [模块二] 16-17 Oct Set 集合,三目运算

    Set 集合 set - unordered collections of unique elements 创建一个set/一个空set # create a new set set1 = {1,2, ...

  3. python自动化测试之函数(匿名函数lambda和三目运算等(高级用法))

    ''' 匿名函数: lambda ''' def Add(a,b): print(a+b) Add(2,3) per = lambda a,b:a+b print(per(2,3)) ''' 三目运算 ...

  4. python 三目运算

    python中的三目运算: result = a if condition else b #当满足condition返回a否则返回b 三目运算可以使你的代码看起来简洁,且运算高效

  5. python函数,lambda表达式,三目运算,列表解析,递归

    一.自定义函数 定义函数时,函数体不执行:只有在调用函数时,函数体才执行.函数的结构: 1. def 2. 函数名 3. 函数体 def func_name(): 函数体 4. 返回值 如果没有声明返 ...

  6. Python学习日记(五)——初识函数(set、深浅拷贝、三目运算、函数、全局变量和局部变量)

    基本数据类型补充 set set集合,是一个无序且不重复的元素集合 #创建 s = {11,22,33,44}#类似字典 s = set() #转换 l = (11,22,33,44) s1 = se ...

  7. python运算符,数据类型,数据类型操作,三目运算,深浅拷贝

    算数运算符: Py2中精确除法需要导入:from __future__ import division,(符由特  ,将来的.滴未省,除法) py3不需要导入 赋值运算符: 比较运算符: 成员运算符: ...

  8. Python—三目运算

    Python 可通过 if 语句来实现三目运算的功能,因此可以近似地把这种 if 语句当成三目运算符.作为三目运算符的 if 语句的语法格式如下: (True_statements) if (expr ...

  9. set集合玩法、三目运算

    set是无序的,无法用下标获取值 创建set二种方式 1.第一种 s1=set()   #创建一个空的set,看下面就知道为什么要这么创建一个空的集合 2.第二种 s2={11,22,33,44} # ...

随机推荐

  1. html+vue.js 实现分页可兼容IE

    当功能比较简单,在单一html中使用vue.js分页展示数据,并未安装脚手架,或使用相关UI框架,此时需要手写一个分页器,不失为最合理最便捷的解决方案, 先看一下实现效果: 上代码: 1.简单搞一搞 ...

  2. 使用docker 部署codis

    使用docker 部署codis 原文地址:https://www.jianshu.com/p/85e72ae6fec3 codis的架构图 1.zookeeeper,用于存放统一配置信息和集群状态 ...

  3. Ros中创建msg和srv遇到的问题

    在创建msg和srv文件之后,使用srv和msg文件时候需要对xml文件进行修改,如下: <build_depend>message_generation</build_depend ...

  4. 新疆地形数据下载:30米、12.5米、5米DEM地形数据

    新疆是我国陆地面积最大的省级行政区,总面积达166万平方公里.新疆的地形也十分的复杂,新疆的地形呈山脉与盆地相间排列,盆地被高山环抱,,俗称"三山夹两盆".三山指阿尔泰山.昆仑山. ...

  5. excel导出csv包括逗号等的处理

    /** * @Title: trimRubbishChar * @Description: 导出的时候需要对一格的内容进行检查,看是否有非法字符,以免串行 * @Since: 2016年8月2日 下午 ...

  6. symbol lookup error /usr/lib/x86_64-linux-gnu/libstdc++.so.6错误的解决办法

    当出现 $ apt-get: symbol lookup error: /usr/lib/x86_64-linux-gnu/libstdc++.so.6: undefined symbol: _ZNS ...

  7. Hive 报错 Failed to load class "org.slf4j.impl.StaticLoggerBinder".

    打开hive报错 SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder". SLF4J: Defaultin ...

  8. Flink处理函数实战之四:窗口处理

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. android下vulkan与opengles纹理互通

    先放demo源码地址:https://github.com/xxxzhou/aoce 06_mediaplayer 效果图: 主要几个点: 用ffmpeg打开rtmp流. 使用vulkan Compu ...

  10. [web安全原理]PHP命令执行漏洞基础

    前言 PHP命令执行漏洞 应用程序的某些功能功能需要调用可以执行系统命令的函数,如果这些函数或者函数的参数被用户控制,就有可能通过命令连接符将恶意命令拼接到正常的函数中,从而随意执行系统命令,这就是命 ...