摘要:主要涉及lambda表达式、python内置函数(open文件重点)、冒泡排序

一、lambda表达式

  适用于创建简单函数,也叫匿名函数, 函数名 = lambda 参数 : 返回值
  function = lambda a1,a2 : a1+a2

二、python内置函数

  abs() 绝对值 print(abs(-12))
     all(iterable) 所有元素为真才为真
     any() 有某个元素为真则为真
     bool()  0,空值,None,空列表 空元组,空字典,空set集合【set()】,空字符串【连空格都没有的】  为假
     bin() 将十进制转换为二进制 0b表示二进制
     oct() 将十进制转化为八进制 0o表示八进制
     int() 单个参数,直接放入数字,就是十进制转换十进制,如果是其他进制转换为十进制,并要求是字符串形式数字,

    int('0b011100',base=2)
       ‘0o + 数字’,表示八进制     base = 2
       ‘0b + 数字’,表示二进制   base = 8
       ‘0x + 数字’,表示十六进制   base = 16
     hex() 将十进制转换为十六进制 0x表示十六进制
     ascii() 不常用,
     bytes() 主要记住字节与字符之间的转换 bytes('字符',encoding='utf-8')
     bytearray() 类似于字节列表
     chr() 将十进制数字转换成ascii对应的字母或数字等 print(chr(65)) --> A
     ord('A') 将字母或数字等转换成对应的ascii十进制数字 print(ord('A'))  --> 65

  isinstance(object,type)  ---> isinstance(args,tuple) ---> True or False 可以用来判断参数的类型是什么

#插播练习
#实现随机验证码 import random temp = ' ' for i in range():
num = random.randrange(,)
if num == or num == :
j = random.randrange(,)
temp = temp + str(j)
else:
h = random.randrange(,)
rad = chr(h)
temp = temp + rad
print(temp)

  callable() 判断是否可执行的, 记住:凡是变量名字后面加() 就是可执行的,返回True,没什么用处的
     compile() 编译代码,
     exec()  只用来执行代码,无返回值 exec('for i in range(4):print i')
     eval()  编译字符串形式的表达式,有返回值 , 例如 a = '1+3'  b = eval(a)  print(b) --> 4
       例如 : ret = eval('a + 99',{'a':100}) ----> print(ret)
     dir()  li = [] ,print(dir(li))
     divmod()  print(divmod(10,3)) --> (3, 1)  (商,余数) 以后可以用在分页方面

  filter(函数,可迭代对象)  筛选,将可迭代对象的元素倒入函数,将返回值为True的元素筛选出来

 def f1(x):
if x > :
return True
else:
return False
ret = filter(f1,[,,,])
for i in ret:
print(i) ----> #或者结合lambda表达式
ret = filter(lambda x : x > ,[,,,])
for i in ret:
print(i)

  map(函数,可迭代对象) 将可迭代元素倒入函数,将函数返回值重新赋值给元素

 ret = map(lambda x : x + 100,[1,2,3,4,5])
print(ret)
for i in ret:
print(i) ----> 101
102
103
104
105 ret = map(lambda x : x + 100 if x % 2 == 1 else x,[1,2,3,4,5])
print(ret)
for i in ret:
print(i) -----> <map object at 0x00000067784C9748>
101
2
103
4
105

  locals()  代码按顺序执行到现在的所有局部变量
      globals() 代码按顺序执行到现在的所有全局变量
      hash() 转变成哈希值,节省空间,可用来给字典的key做优化

  iter() 将括号内容生成为可迭代对象
      next(可迭代对象)  print(next(可迭代对象)) ---> 返回对象的第一个元素,一直next() 可将迭代元素取完,超出会报错
      max() 最大
      min() 最小
      sum() 求和
      pow() 求幂 pow(2,10) 求2的10次方
      round() 四舍五入 print(round(3.3)) ---> 3
      sorted() 数字与字符串不可比较排序,内置函数排序需要是同一种类型

         字符串的排序 : 先是字符串里的数字,再字母,再中文

 li = ['','','abc','','','李强','崔亮','张','王','sb','A','a','B']
q = sorted(li)
print(q)
for j in q:
f = bytes(j,encoding='utf-8')
print(f) ['', '', '', '', 'A', 'B', 'a', 'abc', 'sb', '崔亮', '张', '李强', '王']
b''
b''
b''
b''
b'A'
b'B'
b'a'
b'abc'
b'sb'
b'\xe5\xb4\x94\xe4\xba\xae'
b'\xe5\xbc\xa0'
b'\xe6\x9d\x8e\xe5\xbc\xba'
b'\xe7\x8e\x8b'

  zip(self, iter1, iter2=None, *some)

    l1 = [11,22,33,44]     l2 = [55,66,77,88]

    ret = zip(l1,l2)

    for i in ret:

      print(i)   ---->   (11, 55)
                   (22, 66)
                   (33, 77)
                   (44, 88)

  open(文件名,打开方式)
         普通打开方式:计算机硬盘存储的为0101二进制模式,当通过python打开文件时,默认将二进制转换成字符串显示  ==》字符串类型
          'r' 只可读,为默认的打开方式
          'w' 只可写,不可读,文件不存在则创建,存在则清空文件内容
          'x' 只可写,不可读,文件不存在则创建,存在则报错
          'a' 追加模式,不可读,不存在则创建,存在则只追加内容

     例如:# f = open('test2.py','r')

        # data = f.read()

        # print(data)

        # f.close()

      # f = open('test3.txt','w')

        # f.write('what are you doing?')

        # f.close()

      # f = open('test3.txt','a')

        # f.write('what are you doing?')

        # f.close()

   以二进制方式打开:  ==》字节类型

    'rb' 只可读,以二进制的方式读取

      例如: f = open('text.txt','rb')

         data = f.read()

         print(data)

         str_data = str(data,encoding = 'utf-8')

         f.close()

         print(str_data)

     'wb' 只可写,需要以二进制方式写入

      例如: f = open('text.txt','wb')

         str_name = '中国人'

         bytes_name = bytes(str_name,encoding = 'utf-8')

         f.write(bytes_name)

         f.close()

'xb' 只可写,需要以二进制方式写入

       'ab' 只可写,末尾追加,需要以二进制方式写入

  '+' 表示可以同时读写摸个文件
       r+ 可读写,打开时指针在最开始,【最常用】

      读完之后(也可以只读几个字符,f.read(1) ) ,再写的话,先要调整指针到想要的位置,不调整的话,会在结尾开始写了
          f.tell() 判断指针所在位置,以字节来显示
          f.read(1) 读取一个字符,中文为1个汉字,英文为1个字母
          f.seek(num) 调整指针

     w+ 可写读,先清空,再写(写了指针就到最后),之后再可读
          f = open('test2.py','w+')
          f.write('what are u doing? my love')
          f.seek(0)
          data = f.read()
          f.close()
          print(data)
       x+ 可写读,先清空,再写(写了指针就到最后),之后再可读 【文件存在就会报错】
       a+ 可追加读取,打开的同时将指针调整到最后,再读的话都不到内容的,因为指针在最后,后面没内容了,就算是调整指针,写的话也是在最后开始写

  文件操作方法

    f.flush() 把内存中的write内容刷到硬盘里

      当使用f.write()时,只有全部结束时,才会写入硬盘

    f.read() 可加参数,是按照字符来读取的

    f.readline() 默认值只读取第一行

    f.readlines()  --->生成列表  [‘第一行’,‘第二行’ ...]

    f.write()

    f.tell() 定位指针时,指针是按照字节计算的

    f.seek(num) 修改指针位置,以字节来表示的

    f.truncate() 指针在哪,截取到哪,指针之前都保留

    f.close() 关闭文件

    with open('test2.py','r') as f :   等同于 f = open('test2.py','r')      with 会帮助自动关闭文件

      python2.7之后支持with 同时打开2文件

    with open('log1','r') as f1 ,open('log2','w') as f2:

        for line in f1:

        f2.write(line)

三、冒泡排序
   一个for循环就会将序列编排一次,将最大值放到列表最后

li = [22,11,2,32,9,443,4,53,7554,4321,5652,2,435,67]
for j in range(1,len(li)):
for i in range(len(li) - j):
# current_value = li[i]
# next_value = li[i + 1]
# if current_value > next_value:
# temp = current_value
# current_value = next_value
# next_value = temp
if li[i] > li[i + 1]:
temp = li[i]
li[i] = li[i + 1]
li[i + 1] = temp
print(li) -------> [2, 2, 4, 9, 11, 22, 32, 53, 67, 435, 443, 4321, 5652, 7554]

python基础知识(四)的更多相关文章

  1. Python基础知识(四)

    Python基础知识(四) 一丶列表 定义格式: 是一个容器,由 [ ]表示,元素与元素之间用逗号隔开. 如:name=["张三","李四"] 作用: 存储任意 ...

  2. python基础知识四 小数据池,深浅拷贝,集合+菜中菜

    四.小数据池,深浅拷贝,集合+菜中菜 1小数据池 --缓存机制(驻留机制) ​ '==' 判断两边内容是否相等 ​ 'is' 基于内存地址进行判断是否相同 a = 10 b = 10 print(a ...

  3. python基础知识四

    函数是重用的程序段.它们允许你给一块语句一个名称, 然后你可以在你的程序的任何地方使用这个名称多次地运行这个语句块.这被成为调用函数.我们已经使用了许多内建的函数,比如len和range. 函数通过d ...

  4. Python基础知识(五)------字典

    Python基础知识(四)------字典 字典 一丶什么是字典 ​ dict关键字 , 以 {} 表示, 以key:value形式保存数据 ,每个逗号分隔 ​ 键: 必须是可哈希,(不可变的数据类型 ...

  5. Python基础知识总结笔记(四)函数

    Python基础知识总结笔记(四)函数python中的函数函数中的参数变量作用域偏函数PFA递归函数高阶函数BIFs中的高阶函数匿名函数lambda闭包Closure装饰器Decorator函数式编程 ...

  6. python 基础知识(一)

    python 基础知识(一) 一.python发展介绍 Python的创始人为Guido van Rossum.1989年圣诞节期间,在阿姆斯特丹,Guido为了打发圣诞节的无趣,决心开发一个新的脚本 ...

  7. python 爬虫与数据可视化--python基础知识

    摘要:偶然机会接触到python语音,感觉语法简单.功能强大,刚好朋友分享了一个网课<python 爬虫与数据可视化>,于是在工作与闲暇时间学习起来,并做如下课程笔记整理,整体大概分为4个 ...

  8. python基础知识小结-运维笔记

    接触python已有一段时间了,下面针对python基础知识的使用做一完整梳理:1)避免‘\n’等特殊字符的两种方式: a)利用转义字符‘\’ b)利用原始字符‘r’ print r'c:\now' ...

  9. Python基础知识详解 从入门到精通(七)类与对象

    本篇主要是介绍python,内容可先看目录其他基础知识详解,欢迎查看本人的其他文章Python基础知识详解 从入门到精通(一)介绍Python基础知识详解 从入门到精通(二)基础Python基础知识详 ...

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

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

随机推荐

  1. Linux 内核版本命名

    Linux 内核版本命名在不同的时期有其不同的规范,我们熟悉的也许是 2.x 版本奇数表示开发版.偶数表示稳定版,但到 2.6.x 以及 3.x 甚至将来的 4.x ,内核版本命名都不遵守这样的约定. ...

  2. 用grunt搭建web前端开发环境

    1.前言 本文章旨在讲解grunt入门,以及讲解grunt最常用的几个插件的使用. 2.安装node.js Grunt和所有grunt插件都是基于nodejs来运行的,如果你的电脑上没有nodejs, ...

  3. windows系统下fis3安装教程

    注意:在安装fis3前必须安装node和npm,详情请见官网http://nodejs.org node版本要求 0.8.x,0.10.x, 0.12.x,4.x,6.x,不在此列表中的版本不予支持. ...

  4. Windows远程连接Linux

    目录 xrdp方式 vnc方式 xrdp方式 ----------------------------------------------------------------------------- ...

  5. [LeetCode] Search Insert Position 搜索插入位置

    Given a sorted array and a target value, return the index if the target is found. If not, return the ...

  6. 【wpf】缓存

    1.引用 System.Runtime.Caching 2.源 msdn //实例化MemoryCache类 ObjectCache cache = MemoryCache.Default; //读取 ...

  7. SD卡的监听

    摘要:在一般应用中,如果需要对占用空间比较大的文件操作,需要监听SD卡的状态,Android中对SD卡的监听状态操作步骤如下: 一.创建一个类继承于BroadcastReceiver public c ...

  8. 前端性能优化---yahoo军规

    一.尽可能减少HTTP请求数 二.使用CDN(内容分发网络) 三.添加Expire/Cache-Control头 四.启用Gzip压缩 五.将CSS放在页面最上面 六.将Script放在页面最下面 七 ...

  9. __new__静态方法

    __new__静态方法 新式类都有一个__new__的静态方法,它的原型是object.__new__(cls[, ...]) cls是一个类对象,当你调用C(*args, **kargs)来创建一个 ...

  10. 让PDF.NET支持最新的SQLite数据库

    最近项目中用到了SQLite,之前项目中用的是PDF.NET+MySQL的组合,已经写了不少代码,如果能把写好的代码直接用在SQLite上就好了,PDF.NET支持大部分主流的数据库,这个当然可以,只 ...