热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python之基础篇(三)

基础篇之三:一,数据类型之set.总结:set无序,不重复。1,创建set:s{1,2,3}print(s,type(s))list1[1,2,3]s1(list1)prin

基础篇之三:

一,数据类型之set.

总结:set无序,不重复。

1,创建set:

s = {1,2,3}print(s,type(s))
list1 = [1,2,3]
s1=(list1)
print(s1,type(list1))
s2 = set()
print(s2,type(s2))
{1, 2, 3} [1, 2, 3] set() 

2,set方法

1,添加元素:(s.add)

2,清除元素:(s.clear)

3,s1中存在,s2中不存在:(s3=s1.difference(s2))

4,移除元素并不报错:(s.discard())注:删除的元素不在集合里也不会报错

5,移除并报错:(s.remove())注:删除的元素不在集合里会报错

6,移除某个元素,且随机移除:(s.pop)

7,取交集:(s.intersection)

8,取并集:(s.union)

#实例:s = {1,2,3,4,5}s.add(123)#1,添加元素.addprint(s)#显示结果:{1, 2, 3, 4, 5, 123}02:清除元素 .clears = {1,2,3,4,5}s.clear()print(s)#显示结果:set()#03:s1中存在,s2中不存在:s1 = {11,22,33}s2 = {22,33,44}s3=s1.difference(s2)print(s3)#显示结果:{11}#04:移除指定元素不报错s = {33,4,55,66}s.discard(66)  #移除指定元素 b不报错print(s)#显示结果:{22,4,55}#06:取交集:s1={11,22,33,44}s2={33,44,55}#s.intersection()#取交集s3= s1.intersection(s2)print(s3)#显示结果:{33,44}#07:取并集s1={11,22,33,44}s2={33,44,55}# set.union()#取并集s3= s1.union(s2)print(s3)#显示结果:{33,22,55,11,44}#08:instersection_updetes1 = {11,22,33,44,55}s2 = {11,22,33,44}s1.intersection_update(s2)print(s1)#显示结果:{33, 11, 44, 22}#09集合issubset和issuperset的使用s1 = {11,22,33,44,55}s2 = {11,22,33,44}s3 = {66,77,88}s4 = s2.issubset(s1)s5 = s1.issuperset(s2)print(s4)print(s5)#显示结果:TrueTrue

二:集合的应用:

CMDB

old_dict = {    "#1":8,    "#2":4,    "#4":2,}new_dict = {    "#1":4,    "#2":4,    "#3":2,} renew_dict = {    "#1":4,    "#2":4,    "#3":2,}

思路:

应该删除哪几个槽位:old中存在的new不存在  old.difference(new)应该更新哪几个槽位:new中存在old中不存在  new.difference(old)应该增加哪几个槽位:old和new中都存在      old.intersection(new)old:  new:  第一步:将第二步:更新old_dict存在,new不存在old_keys = old_dict.keys()new_keys = new_dict.keys()old_set = (old_keys)new_set = (new_keys)remove_set = old_set.difference(new_set)new中存在,old中不存在remove_set = new_set.difference(old_set)new和old中都存在update_set = old_set.intersection(new_set)

代码:

old_keys = old_dict.keys()old_set = set(old_keys)new_keys = new_dict.keys()new_set = set(new_keys)print(new_set)print(old_set) remove_set = old_set.difference(new_set)add_set = new_set.difference(old_set)update_set = new_set.intersection(old_set)print(remove_set)print(add_set)print(update_set)

三:函数

函数:自定义函数与内置函数.

函数:

1,def关键字,创建函数。

2,函数名 函数的名称,日后根据函数名调用函数

3,参数 为函数体提供数据

4,函数体 函数中进行一系列的逻辑计算,如:发送邮件、计算出 [11,22,38,888,2]中的最大数等...

5,返回值 当函数执行完毕后,可以给调用者返回数据。

例子:

def 函数名(参数):         ...    函数体    ...    return

返回值:函数是一个功能块,该功能到底执行成功与否,需要通过返回值来告知调用者。

def 发送短信():         发送短信的代码...     if 发送成功:        return True    else:        return False  while True:         # 每次执行发送短信函数,都会将返回值自动赋值给result    # 之后,可以根据result来写日志,或重发等操作     result = 发送短信()    if result == False:        记录日志,短信发送失败...

参数:

#函数的基本参数

#1,形式参数

#2,实际参数

#3,默认参数   必须放在参数列表末尾

#4,指定参数

#5,动态参数   *   **  args   kwargs

# ######### 定义函数 ########## name 叫做函数func的形式参数,简称:形参def func(name):    print(name)# ######### 执行函数 ##########  'anka' 叫做函数func的实际参数,简称:实参func("anka")
def func(name, age = 18):    print("%s:%s" %(name,age))# 指定参数func('anka', 19)# 使用默认参数func('leo')注:默认参数需要放在参数列表最后默认参数#显示结果:anka:19leo:18
ef func(*args):    print(args)# 执行方式一func(11,33,4,4454,5)# 执行方式二li = [11,2,2,3,3,4,54]func(*li)#动态参数一#显示结果:(11, 33, 4, 4454, 5)(11, 2, 2, 3, 3, 4, 54)

指定函数:

#指定参数:即指定将实参赋值给哪个形参,此时可以不按照顺序来写def send(xxoo,content,xx='hello world'):    print(xxoo,content,xx)    print('邮件发送成功',xxoo,content)    return Truewhile True:    em = input('请输入邮箱地址:')    #result = send(em,'Test',)    result = send(em,xx='Test',cOntent='OK')    if result == True:        print('发送成功')    else:        print('发送失败')#显示结果:请输入邮箱地址:619569405@qq.com619569405@qq.com OK Test邮件发送成功 619569405@qq.com OK发送成功

动态参数扩展:

eg01:多个单个变量,整合成元组

def f1(*args):    print(args,type(args)) f1(11)f1([1,2,3,4,])l1 = [1,2,3,4,4,5,6]f1(l1)f1(*l1)str1 = 'alex'f1(str1)f1(*str1)#显示结果:(11,) ([1, 2, 3, 4],) ([1, 2, 3, 4, 4, 5, 6],) (1, 2, 3, 4, 4, 5, 6) ('alex',) ('a', 'l', 'e', 'x') 

eg02:一定要注意加*和不加*的区别:

01,不加*,则是将整个列表作为一个元组

02,加* 将列表中的每一个元素转换为元组一个元素,如果是字符串,则将字符串转换为元组的一个元素。

 整合为字典变量

def f1(**args):    print(args,type(args))f1(n1='alex',n2=38)dic = {'k1':'v1','k2':'v2'}f1(**dic)#显示结果:{'n1': 'alex', 'n2': 38} {'k1': 'v1', 'k2': 'v2'} 

eg03:整合*args,**kwargs

def f1(*args,**kwargs):    print(args)    print(kwargs)f1(11,22,33,44,k1='v1',k2='v2',n1='www',n2='sss')#显示结果:(11, 22, 33, 44){'k2': 'v2', 'n2': 'sss', 'k1': 'v1', 'n1': 'www'}

eg04:字符串的格式化.format

#可变参数*的应用s = 'I AM {0},age {1}'.format('alex',38)print(s)s2 = 'I AM {0},age {1}'.format(*['alex',18])print(s2)#可变参数**的应用s3 = 'I AM {name},age {age}'.format(name='alex',age=38)print(s3)dic = {'name':'alex','age':38}s4 = 'I AM {name},age {age}'.format(**dic)print(s4)#显示结果:I AM alex,age 38I AM alex,age 18I AM alex,age 38I AM alex,age 38

内置函数:

wKioL1d5-HbggrfpAAI_U8-cYHo194.png-wh_50

n = abs(-1)   #求绝对值print(n)#0,None,"",[],{},():Falseprint(all([1,2,3,4]))  #每个元素都为真结果才为真print(all([1,2,3,0]))  print(any([1,2,3,0]))  #有一个元素为真返回结果就为真print(bin(5))       #把十进制数字转换为二进制print(oct(5))       #把十进制数字转换为八进制print(hex(5))       #把十进制数字转换为十六进制print(bool(0))       #布尔值,返回结果为False或者是True#打印结果:1TrueFalseTrue0b1010o50x5False

函数作用域:

def say():    name = "mohan"    print(name)say()#mohan  # 是没有问题的,那么看下下面的例子:def say():    name = "mohan"    print(name)say()print(name)# 这个能不能调用呢,不能,会报错!函数的作用域就是在函数里定义的变量不能被外面使用!

继续:

name2 = "mohan"def say():    name = "yamei"    print name    print name2say()#输出结果:yameimohan

总结:函数的作用域就是在函数里定义的变量他的作用域是函数体内部,不能被外面使用!但是外部全局定义的全局变量在函数内是可以使用的。

举个例子来说:你在房子里可以看到屋内的东西和房子外的东西,但是你在房子外面就只能看到房子外的东西不能看到房子内的东西!

原因防止在函数调用的时候防止变量冲突!

问题:我在外面定义的全局变量在函数内可以改他吗?  #看下面的例子:

name2 = "meinv"def say():    name = "hanyue"    name2 = "hanyue is meinv"    print(name,name2)say()print(name2)#显示结果:hanyue hanyue is meinv#在函数内改变了meinv#但是外面调用还是没有改变

但是我就想在函数内改掉这个变量怎么办呢?在函数内调用global参数!(提供这个功能,但是不建议用!你在局部变量改全局变量很容易引起混乱)

name2 = "meinv"def say():    global name2    name = "hanyue"    name2 = "hanyue is meinv"    print(name,name2)say()print(name2)#显示结果:hanyue hanyue is meinvhanyue is meinv

四:文件操作

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

#python中打开文件有两种方式,即:open(...) 和  file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open(),python2,open()和file()可以正常使用,python3.0以后file方法讲被用做其他,open方法会自动的去帮你找他调用得方法在那里!

开文件时,需要指定文件路径和以何等方式打开文件,打开后,即可获取该文件句柄,日后通过此文件句柄对该文件操作。 打开文件的模式有: r,只读模式(默认)。w,只写模式。【不可读;不存在则创建;存在则删除内容;】a,追加模式。【可读;   不存在则创建;存在则只追加内容;】"+" 表示可以同时读写某个文件 r+,可读写文件。【可读;可写;可追加】w+,无意义a+,同a"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用) rUr+U"b"表示处理二进制文件(如:FTP发送上传ISO镜像文件,linux可忽略,windows处理二进制文件时需标注) rbwbab
2.操作文件f.read()read()#无参数,读取全部,有参数  b按照字节,无b按照字符tell():获取当前指针位置seek():跳转到指定位置write():写数据close():关闭文件fileno():文件描述符flush():把写入的内容强制刷新到磁盘上readable():是否可读readline():仅读取一行seekable():是否可移动truncate():截取数据,指针位置之后的全部清空readlines():for循环文件句柄 f = open(xxxx)for line in f:    print(line)

3,with

为了避免打开文件后忘记关闭,可以通过管理上下文,即:

with open('log','r') as f:

如此方式,当with代码块执行完毕时,内部会自动关闭并释放文件资源。

例子:比如要修改nginx.conf 文件然后还需要回滚怎么做?

with open('nginx.conf','r') as obj1,open('nginx.conf.new','w') as obj2:    for i in obj1.readlines():        i = i.strip()        print i        obj2.write(i)        obj2.write('\n') #读取nginx.conf每行然后存储到新的文件nginx.conf.new里!


本文出自 “小虫的快乐” 博客,请务必保留此出处http://bughapply.blog.51cto.com/744579/1795500


推荐阅读
  • 本文分享了作者在使用LaTeX过程中的几点心得,涵盖了从文档编辑、代码高亮、图形绘制到3D模型展示等多个方面的内容。适合希望深入了解LaTeX高级功能的用户。 ... [详细]
  • 一.数据基本类型之set集合set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在se ... [详细]
  • 本文详细探讨了编程中的命名空间与作用域概念,包括其定义、类型以及在不同上下文中的应用。 ... [详细]
  • 本文详细介绍了Socket在Linux内核中的实现机制,包括基本的Socket结构、协议操作集以及不同协议下的具体实现。通过这些内容,读者可以更好地理解Socket的工作原理。 ... [详细]
  • 2023年1月28日网络安全热点
    涵盖最新的网络安全动态,包括OpenSSH和WordPress的安全更新、VirtualBox提权漏洞、以及谷歌推出的新证书验证机制等内容。 ... [详细]
  • 利用Docker部署JupyterHub以支持Python协同开发
    本文介绍了如何通过Docker容器化技术安装和配置JupyterHub,以实现多用户的Python开发环境,特别适合团队协作场景。 ... [详细]
  • 本文详细介绍了如何在PHP中使用Memcached进行数据缓存,包括服务器连接、数据操作、高级功能等。 ... [详细]
  • Python网络编程:深入探讨TCP粘包问题及解决方案
    本文详细探讨了TCP协议下的粘包现象及其产生的原因,并提供了通过自定义报头解决粘包问题的具体实现方案。同时,对比了TCP与UDP协议在数据传输上的不同特性。 ... [详细]
  • 本文介绍了使用Python和C语言编写程序来计算一个给定数值的平方根的方法。通过迭代算法,我们能够精确地得到所需的结果。 ... [详细]
  • Linux内核中的内存反碎片技术解析
    本文深入探讨了Linux内核中实现的内存反碎片技术,包括其历史发展、关键概念如虚拟可移动区域以及具体的内存碎片整理策略。旨在为开发者提供全面的技术理解。 ... [详细]
  • 本文介绍了如何通过安装和配置php_uploadprogress扩展来实现文件上传时的进度条显示功能。通过一个简单的示例,详细解释了从安装扩展到编写具体代码的全过程。 ... [详细]
  • 苹果官方在线商店(中国)提供了关于MacBook Pro的详细信息。通过先进的工厂校准技术,新MacBook Pro能够精确地适应多种色彩空间标准,如sRGB、BT.601、BT.709及P3-ST.2084(HDR),确保用户获得最佳视觉效果。 ... [详细]
  • 在使用mybatis进行mapper.xml测试的时候发生必须为元素类型“mapper”声明属性“namespace”的错误项目目录结构UserMapper和UserMappe ... [详细]
  • 一、使用Microsoft.Office.Interop.Excel.DLL需要安装Office代码如下:2publicstaticboolExportExcel(S ... [详细]
  • 汇总了2023年7月7日最新的网络安全新闻和技术更新,包括最新的漏洞披露、工具发布及安全事件。 ... [详细]
author-avatar
红箭777_387
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有