Python Day03

集合操作:

     ·去重,把一个列表边城集合,就自动去重

     ·关系测试,测试两组数据之前的交集、差集、并集等关系


list_1 = set(list_1)             #列表转化为集合,自动去重

list_1.intersection(list_2)      #交集   等效             a = list_1 & list_2

list_1.union(list_2)             #并集  等效                    a = list_1 | list_2

list_1.difference(list_2)      #保留list_1中有的,list_2里没有的       等效          a = list_1 - list_2

list_1.issubset(list_2)           #判断子集

list_1.issuperset(list_2)             #判断父级集

list_1.symmetric_difference(list_2)      #去掉交集的并集集合,对称差集      等效    a = list_1 ^ list_2

增:

      ·list_1.add(999)

      ·list_1.update([122,223,445]) #添加多项

删:

      ·list_1.remove(3) #删除数字3

      ·lisr_1.pop()    #随机删除

改:

查:

    ·print(len(list_1)) #字典长度


文件操作

流程:

  ·打开文件,得到文件句柄并赋值给一个变量

  ·通过句柄对文件进行操作

  ·关闭文件

f = open("yesterday", 'r', encoding="utf-8")  #文件赋值给f变量,再操作------文件句柄

'r'--指定模式,读

  ·print(f.readline()) #单行读取

  ·for i in range(3):

   print(f.readline())  #多行读取

  ·for index, line in enumerate(f.readlines()):  #循环读取

   if index == 9:

        print('=======================')

        continue

  print(line.strip())        #strip 把换行和空格都删除



Python Day03_第1张图片

'w'--写,覆盖之前的

'a'--追加, 不覆盖之前的数据


f.truncate(10)  #截断, 不写就是清空,指定就从头截断到指定位置

print(f.read(5))    #读五个

print(f.tell())    #读取文件的位置

f.seek(0)          #返回文件起始位置,可选择行数

print(f.encoding)  #打印文件编码

print(f.fileno())  #返回文件句柄的编号

"+" 表示可以同时读写某个文件:

·r+,可读写文件。【可读;可写;可追加】,写在最后

·w+,写读 ,先创建

·a+,同a

"U"表示在读取时,可以将 \r \n \r\n自动转换成 \n (与 r 或 r+ 模式同使用)

·rU

·r+U

"b"表示处理二进制文件,二进制文件用二进制读取,避免损坏

·rb

·wb

·ab

f = open("yesterday2", 'rb')

f.write("hellow binary\n".encode()) #写入转码

练习:修改一个文件,先把“yesterday2”,复制到新的文件“yesterday2.bp”中,再分别赋值给"f","f_new"。再找到需要修改的位置,进行替换。最后关闭文件


Python Day03_第2张图片


字符编码与转码

不同编码的转化先转化成 Unicode


Python Day03_第3张图片


例:

s = "你好"                                          #unicode 字符串编码

print(s.encode("gbk"))                       #转化为gbk编码

print(s.encode("utf-8"))                     #转化为utf-8编码


#先用编码成utf-8,再用utf-8解码为u字符串,再用gb2312编码

print(s.encode("utf-8").decode("utf-8").encode("gb2312"))


#先用编码成utf-8,再用utf-8解码为u字符串,再用gb2312编码,再用gb2312解码为字符串

print(s.encode("utf-8").decode("utf-8").encode("gb2312").decode("gb2312"))


编程方法:

·面向对象:  -----类    class

·面向过程:  -----过程  def

·函数式编程:-----函数  def

函数是裸机结构化和过程化的一种编程方法

优点:

·代码重用,减少重复

·保持一致性

·可扩展性

返回值:

·返回值数 = 0;返回none

·返回值数 = 1;返回object--对象

·返回值数 > 1;返回tuple--元组

参数:

·形参和实参

形参:不是实际存在的,是虚拟变量。在定义函数和函数体的时候使用形参,目的是在函数调用时

接受实参。(一一对应)

实参:实际参数,调用函数式传给函数的参数,可以是常量,变量,表达式,函数,传给形参

区别:形参是虚拟的,不占用内存空间,形参变量只有在被调用的时候才会分配内存单元;实参是

一个变量,占用内存空间,数据传送单向——实参传给形参,不能形参传给实参

·位置参数和关键字(关键字在位置参数后边;实参与形参一一对应;关键字调用)

   *args-- 接收N个位置参数,转化为元组的形式

   **kwargs--接收N个关键字参数,转化成字典的方式

·默认参数

·参数组   --(*—)


局部变量:局部变量只在函数里生效,函数为这个变量的作用域

   global school 在函数中声明修改全局变量------(千万别使用,会导致逻辑混乱)

Python Day03_第4张图片

全局与局部变量:

   ·在子程序中定义的变量成为局部变量,在程序的一开始定义的变量称为全局变量。

   ·全局变量作用域为整个程序,局部变量是作用域是定义该变量的子程序

   ·当全局变量和局部变量同名时:

            在定义局部变量的子程序中,局部变量起作用,在其他地方,全局变量起作用

     递归:函数内部可以调用其他函数,如果一个函数在内部调用自己本身,就为递归函数。

特性:

   ·必须有一个明确的结束条件

   ·每次进入深一层递归是,问题规模相比上次递归应有减少

   ·递归效率不高,递归层次过多会导致栈溢出


Python Day03_第5张图片
简单的递归实现


Python Day03_第6张图片
高阶函数的简单实现

你可能感兴趣的:(Python Day03)