python Day13

  • 匿名函数(一句话函数,比较简单的函数)

    • func=lambda a,b:a+b
      print(func(1,2))
      ###结果:3
    • func=lambda a:(a[0],a[2])
      print(func("dsfds"))
    • func_max=lambda a,b:a if a>b else b
      print(func_max(3,2))
  • 内置函数扩展

    • bin将10进制转换为二进制并返回

    • oct将10进制转化为八进制字符并返回

    • hex将10进制转化为16进制并返回

    • divmodf :返回除数与被除数的结果

      print(divmod(10,3))
      ###结果(3, 1)
    • round:保留浮点数的小数位数

      print(round(3.2243252543,2))
      ###结果3.22
    • pow:求x的y次幂

      print(pow(2,3))
      ##结果 8

+ bytes ~~~python
s1="电话卡"
print(bytes(s1,encoding="utf-8"))
##结果 b'\xe7\x94\xb5\xe8\xaf\x9d\xe5\x8d\xa1'
  • chr:输入位置数字找出来其对应的字符

    print(chr(97))
    ## a
  • reversed返回的是一个翻转的迭代器

    list1=[i for i in range(10)]
    obgj=reversed(list1)
    print(obgj)
    print(list(obgj))
    ###结果 :<list_reverseiterator object at 0x000001DD79831948>
    ## [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
  • zip 拉链的方法

    li=[1,23,4,4,55]
    tu1=("太白","猴哥","单反")
    s1="fsfsdfdsf"
    print(list(zip(li,tu1,s1)))
    ###结果[(1, '太白', 'f'), (23, '猴哥', 's'), (4, '单反', 'f')]
  • min,max的扩展用法

    #以绝对值的形式输出列表的最小值
    ###凡是可以加key的,它会自动的将可迭代对象中的每个元素按照顺序传入对应的函数中
    li=[1,23,4,4,55,-1]
    print(min(li,key=abs))##key 后面跟着函数
    ##1
    ######
    l11=[('太白',18),("alex",73),("wusir",35),("口天吴",41)]
    def func(a):
    return a[1]
    print(min(l11,key=func))#min替换成sorted也是可以的
    ####结果:('太白', 18)
  • filter 列表推导式的筛选模式

    l1=[1,2,3,4,55]
    l2=list(filter(lambda x:x>3,l1))
    print(l2)
    ###结果[4, 55]
  • map 列表推导式的循环模式,吧列表中中每个元素输入进去

    l1=[1,2,3,4,55]
    ret=map(lambda x:x**2,range(1,6))
    print(list(ret))
    ##结果是迭代器的模式
  • 闭包

    • 内存函数对外层函数非全局变量的引用(使用),就会形成闭包。被引用的非全局变量也称做自由变量,这个自由变量会与内层函数产生一个绑定关系,自由变量不会再内存中消失。(保证数据的安全)

    • 闭包只能存在嵌套函数中

      def make_average():
      l1=[]
      def average(new_price):
      l1.append(new_price)
      total=sum(l1)/len(l1)
      return total
      return average
      avg=make_average()
      print(avg(1000))
      print(avg(2000))
  • 作业

    • 看代码写结果

      def add(n,i):
      return n+i
      def test():
      for i in range(4):
      yield i
      g=test()
      for n in [1,10]:
      g=(add(n,i) for i in g)
      print(list(g))
      ###结果 [20, 21, 22, 23]
      ####解析
      因为第二次循环n一直就是10了
      list(g)=list((add(10,i) for i in add(10,i) for i in test()))
      list(g)=list((add(10,i) for i in add(10,i) for i in test[0,1,2,3]))
      list(g)=list((add(10,i) for i in ([10,11,12,13])
    • 用map来处理字符串列表,把列表中所有人都变成sb,比如fengchao_sb

      name=["zhuxiayu","fengchao","wusir"]
      new_name=map(lambda x:x+"_sb",name)
      print(list(new_name))
      ###结果 ['zhuxiayu_sb', 'fengchao_sb', 'wusir_sb']
    • 用map来处理下述l,然后用lsit得到一个新的列表,列表中每人的名字都是sb结尾

      l=[{"name":"服务器"},{"name":"服务器2"}]
      new_l=map(lambda x:x["name"]+"sb",l)
      print(list(new_l))
      ###结果 ['服务器sb', '服务器2sb']
    • 写代码,最终得到的结果是(每个元组第一个元素>2,第三个*至少是4个)

      l1=[1,2,3,4,5,6,7]
      l2=["oldboy","axle","wusir","白天","天日"]
      tu=("**","***","*****","********")
      new=zip(l1,l2,tu)
      new_list=list(new)
      ret=filter(lambda x:x[0]>2 and len(x[2])>3,new_list)
      print(list(ret))
      ###结果[(3, 'wusir', '*****'), (4, '白天', '********')]
    • 将l1按照列表中每个字典的values大小进行排序,形成一个新的列表

      l1=[{'sales_volumn':0},
      {'sales_volumn':108},
      {'sales_volumn':337},
      {'sales_volumn':475},
      {'sales_volumn':396},
      {'sales_volumn':172},
      {'sales_volumn':9},
      {'sales_volumn':58},
      {'sales_volumn':272},
      {'sales_volumn':456},
      {'sales_volumn':440},
      {'sales_volumn':239},
      ]
      print(list(sorted(l1,key=lambda x:x["sales_volumn"])))
    • 看代码写结果

      v=[lambda :x for x in range(10)]
      print(v)
      print(v[0])
      ##结果:[<function <listcomp>.<lambda> at 0x000002AA60EBE168>, <function <listcomp>.<lambda> at 0x000002AA60EB93A8>, <function <listcomp>.<lambda> at 0x000002AA60FC4C18>, <function <listcomp>.<lambda> at 0x000002AA610B5A68>, <function <listcomp>.<lambda> at 0x000002AA610BC5E8>, <function <listcomp>.<lambda> at 0x000002AA610BCC18>, <function <listcomp>.<lambda> at 0x000002AA610C1EE8>, <function <listcomp>.<lambda> at 0x000002AA610C1438>, <function <listcomp>.<lambda> at 0x000002AA620BF3A8>, <function <listcomp>.<lambda> at 0x000002AA620BF438>]
      <function <listcomp>.<lambda> at 0x000002AA60EBE168>
    • 写一个函数完成三次登录功能,用户的用户名密码从一个文件register中取出,register文件包含多个用户名,密码,用户名密码通过|隔开,每个人的用户名密码占用文件中一行,完成三次实验,三次实验不成功则登录失败,失败则返回false

      def get_user_dict():
      user_dict={}
      with open("register.txt",encoding="utf-8",mode="r") as file:
      for line in file:
      username1,password1=line.strip("\n").split("|")
      user_dict[username1]=password1
      return user_dict
      def log_in():
      user_dict=get_user_dict()
      count=1
      while count<4:
      username=input("please input your name:").strip("") password=input("please input your password").strip("")
      if username in user_dict and password==user_dict[username]:
      print("登录成功")
      return True
      else:
      count+=1
      else:
      return False
      log_in()

python基础 Day13的更多相关文章

  1. python之最强王者(2)——python基础语法

    背景介绍:由于本人一直做java开发,也是从txt开始写hello,world,使用javac命令编译,一直到使用myeclipse,其中的道理和辛酸都懂(请容许我擦干眼角的泪水),所以对于pytho ...

  2. Python开发【第二篇】:Python基础知识

    Python基础知识 一.初识基本数据类型 类型: int(整型) 在32位机器上,整数的位数为32位,取值范围为-2**31-2**31-1,即-2147483648-2147483647 在64位 ...

  3. Python小白的发展之路之Python基础(一)

    Python基础部分1: 1.Python简介 2.Python 2 or 3,两者的主要区别 3.Python解释器 4.安装Python 5.第一个Python程序 Hello World 6.P ...

  4. Python之路3【第一篇】Python基础

    本节内容 Python简介 Python安装 第一个Python程序 编程语言的分类 Python简介 1.Python的由来 python的创始人为吉多·范罗苏姆(Guido van Rossum) ...

  5. 进击的Python【第三章】:Python基础(三)

    Python基础(三) 本章内容 集合的概念与操作 文件的操作 函数的特点与用法 参数与局部变量 return返回值的概念 递归的基本含义 函数式编程介绍 高阶函数的概念 一.集合的概念与操作 集合( ...

  6. 进击的Python【第二章】:Python基础(二)

    Python基础(二) 本章内容 数据类型 数据运算 列表与元组的基本操作 字典的基本操作 字符编码与转码 模块初探 练习:购物车程序 一.数据类型 Python有五个标准的数据类型: Numbers ...

  7. Python之路【第一篇】python基础

    一.python开发 1.开发: 1)高级语言:python .Java .PHP. C#  Go ruby  c++  ===>字节码 2)低级语言:c .汇编 2.语言之间的对比: 1)py ...

  8. python基础之day1

    Python 简介 Python是著名的“龟叔”Guido van Rossum在1989年圣诞节期间,为了打发无聊的圣诞节而编写的一个编程语言. Python为我们提供了非常完善的基础代码库,覆盖了 ...

  9. python基础之文件读写

    python基础之文件读写 本节内容 os模块中文件以及目录的一些方法 文件的操作 目录的操作 1.os模块中文件以及目录的一些方法 python操作文件以及目录可以使用os模块的一些方法如下: 得到 ...

随机推荐

  1. springboot(九)文件上传

    在企业级项目开发过程中,上传文件是最常用到的功能.SpringBoot集成了SpringMVC,当然上传文件的方式跟SpringMVC没有什么出入.下面我们来创建一个SpringBoot项目完成单个. ...

  2. Mybatis(四)多表操作

    数据库如下: 一.创建数据库所对应的bean类 public class User { private Integer uId; private String username; private St ...

  3. hadoop2.7.3+spark2.0.1+scala2.11.8集群部署

    一.环境 4.用户 hadoop 5.目录规划 /home/hadoop/app    #程序目录 /home/hadoop/data  #数据目录     #打开文件的最大数 vi /etc/sec ...

  4. mysql性能优化方案总结

    一.表结构优化 1.根据自己的业务选择合适的引擎.比如: 在以下两点情况下必须使用InnerDB: ①可靠性高或者必须要求事务处理 ②表更新和查询相当的频繁,并且表锁定的机会比较大的情况下,指定Inn ...

  5. break statement not within loop or switch报错

    break statement not within loop or switch. 注意你的循环,可能多加了个分号.for语句后面?

  6. [USACO09NOV]硬币的游戏 博弈 dp

    LINK : coin game 这道题 超级经典去年这个时候我就看过题目了 但时至今日还不会/cy 觉得在做比赛的题目的时候少写省选的题目 多做水题多做不难也不简单的题目就好了. 由于我是真的不会博 ...

  7. 代码扫描Sonar使用教程

    Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从多个维度检测代码质量: 可靠性 安全性 可维护性 覆盖率 重复率 通过插件形式,可以支持包括Java,C#,C/C++,PL/S ...

  8. x86架构:分页机制和原理

    分页是现在CPU核心的管理内存方式,网上介绍材料很多,这里不赘述,简单介绍一下分页的背景和原理 1.先说说为什么要分段 实模式下程序之间不隔离,互相能直接读写对方内存,或跳转到其他进程的代码运行,导致 ...

  9. Logback日志格式优化,解决输出***@2b193f2d问题

    原文出处:Java之道 原文地址:http://www.hollischuang.com/archives/3689 我们在开发的时候,经常要打印日志,有的时候会在一些代码的关键节点处进行日志输出.使 ...

  10. JavaWeb项目的部署以及远程调试

    Linux环境下软件的安装 Linux环境下的程序的安装.更新.卸载和查看. rpm 命令:相当于windows程序的添加/卸载程序,进程程序的安装,查看,卸载. 本地程序安装:rpm -ivh 程序 ...