热门标签 | 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


推荐阅读
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了Composer依赖管理的重要性及使用方法。对于现代语言而言,包管理器是标配,而Composer作为PHP的包管理器,解决了PEAR的问题,并且使用简单,方便提交自己的包。文章还提到了使用Composer能够避免各种include的问题,避免命名空间冲突,并且能够方便地安装升级扩展包。 ... [详细]
  • 本文介绍了Python语言程序设计中文件和数据格式化的操作,包括使用np.savetext保存文本文件,对文本文件和二进制文件进行统一的操作步骤,以及使用Numpy模块进行数据可视化编程的指南。同时还提供了一些关于Python的测试题。 ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 在Docker中,将主机目录挂载到容器中作为volume使用时,常常会遇到文件权限问题。这是因为容器内外的UID不同所导致的。本文介绍了解决这个问题的方法,包括使用gosu和suexec工具以及在Dockerfile中配置volume的权限。通过这些方法,可以避免在使用Docker时出现无写权限的情况。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Python如何调用类里面的方法
    本文介绍了在Python中调用同一个类中的方法需要加上self参数,并且规范写法要求每个函数的第一个参数都为self。同时还介绍了如何调用另一个类中的方法。详细内容请阅读剩余部分。 ... [详细]
  • 本文介绍了使用PHP实现断点续传乱序合并文件的方法和源码。由于网络原因,文件需要分割成多个部分发送,因此无法按顺序接收。文章中提供了merge2.php的源码,通过使用shuffle函数打乱文件读取顺序,实现了乱序合并文件的功能。同时,还介绍了filesize、glob、unlink、fopen等相关函数的使用。阅读本文可以了解如何使用PHP实现断点续传乱序合并文件的具体步骤。 ... [详细]
  • 本文介绍了计算机网络的定义和通信流程,包括客户端编译文件、二进制转换、三层路由设备等。同时,还介绍了计算机网络中常用的关键词,如MAC地址和IP地址。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • 本文介绍了在Windows系统下安装Python、setuptools、pip和virtualenv的步骤,以及安装过程中需要注意的事项。详细介绍了Python2.7.4和Python3.3.2的安装路径,以及如何使用easy_install安装setuptools。同时提醒用户在安装完setuptools后,需要继续安装pip,并注意不要将Python的目录添加到系统的环境变量中。最后,还介绍了通过下载ez_setup.py来安装setuptools的方法。 ... [详细]
  • 本文详细介绍了PHP中与URL处理相关的三个函数:http_build_query、parse_str和查询字符串的解析。通过示例和语法说明,讲解了这些函数的使用方法和作用,帮助读者更好地理解和应用。 ... [详细]
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社区 版权所有