摘要:主要涉及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. RedHat 和 Mirantis OpenStack 产品的版本和功能汇总和对比(持续更新)

    Mirantis 和 Red Hat 作为 OpenStack 商业化产品领域的两大领军企业,在行业内有重要的地位.因此,研究其产品版本发布周期和所支持的功能,对制定 OpenStack 产品的版本和 ...

  2. HDOJ 2111. Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  3. Java的JDBC操作

    Java的JDBC操作 [TOC] 1.JDBC入门 1.1.什么是JDBC JDBC从物理结构上来说就是java语言访问数据库的一套接口集合,本质上是java语言根数据库之间的协议.JDBC提供一组 ...

  4. MongoDB数据库的CURD的一些基本语句

    from:http://www.data321.com/shujuku/20160514417/addToSetQianMianBuXuYaoJinXing 插入文档: SQL语句: INSERT I ...

  5. redis 学习笔记(7)-cluster 客户端(jedis)代码示例

    上节学习了cluster的搭建及redis-cli终端下如何操作,但是更常用的场景是在程序代码里对cluster读写,这需要redis-client对cluster模式的支持,目前spring-dat ...

  6. [LeetCode] Nth Digit 第N位

    Find the nth digit of the infinite integer sequence 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, ... Note: n i ...

  7. [LeetCode] Find Minimum in Rotated Sorted Array 寻找旋转有序数组的最小值

    Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...

  8. JS组件系列——BootstrapTable 行内编辑解决方案:x-editable

    前言:之前介绍bootstrapTable组件的时候有提到它的行内编辑功能,只不过为了展示功能,将此一笔带过了,罪过罪过!最近项目里面还是打算将行内编辑用起来,于是再次研究了下x-editable组件 ...

  9. Mysql操作语句

    MySQL中定义数据字段的类型对你数据库的优化是非常重要的. MySQL支持多种类型,大致可以分为三类:数值.日期/时间和字符串(字符)类型. 数值类型 MySQL支持所有标准SQL数值数据类型. 这 ...

  10. Spring Aspectj切入点语法定义

    在使用spring框架配置AOP的时候,pointcut"切入点" 例如定义切入点表达式 execution(* com.sample.service.impl..*.*(..)) ...