首页 > 代码库 > Python基础学习(四)

Python基础学习(四)

Python 集合:

    set 顾明思义,就是个集合,集合的元素是唯一的,无序的。一个{ }里面放一些元素就构成了一个集合,set里面可以是多种数据类型(但不能是列表,集合,字典,可以是元组)

    它可以对列表里面的重复元素进行去重

list1 = [1,2,3,23,1,4,2]
list1 = set(list1)

集合的关系测试:

a = {1,2,3,4,5}
b = {1,3,5,7,9}

a.symmetric_difference(b) #对称差集
a.difference(b) #差集
a.intersection(b) #交集
a.union(b) #并集


Python之文件操作:


    ptython 不同模式打开文件的完全列表:

模式描述
r以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。
r+打开一个文件用于读写。文件指针将会放在文件的开头。
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
w打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
w+打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。


    File文件对象属性

    一个文件被打开后,你有一个file对象,你可以得到有关该文件的各种信息。

    以下是和file对象相关的所有属性的列表:

属性描述
file.closed返回true如果文件已被关闭,否则返回false。
file.mode返回被打开文件的访问模式。
file.name返回文件的名称。
file.softspace如果用print输出后,必须跟一个空格符,则返回false。否则返回true。


Python之字符集编码:

  1. py2里默认编码是ascii

  2. Python3.x 源码文件默认使用utf-8编码,所以可以正常解析中文,无需指定utf-8编码。



    转码:

    技术分享


Python 函数

    函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段。

    函数能提高应用的模块性,和代码的重复利用率。你已经知道Python提供了许多内建函数,比如print()。但你也可以自己创建函数,这被叫做用户自定义函数。


    定义一个函数

            你可以定义一个由自己想要功能的函数,以下是简单的规则:


    • 函数代码块以 def 关键词开头,后接函数标识符名称和圆括号()

    • 任何传入参数和自变量必须放在圆括号中间。圆括号之间可以用于定义参数。

    • 函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明。

    • 函数内容以冒号起始,并且缩进。

    • return [表达式] 结束函数,选择性地返回一个值给调用方。不带表达式的return相当于返回 None。


    函数参数:

        1.默认参数,如下:address 就是一个默认参数,在没有传入值的情况下默认为“CN”;

def test(name,age,address="CN"):
    print("name:",name)
    print("age:",age)
    print("address", address)

test("lilei", 18)

        2.位置参数,传入的参数一一对应,不能多也不能少;

test("lilei", 18, "US")

        3.关键字参数,可以无序,可以和位置参数公用,但位置参数必须在关键字参数之前。

test(age=18,name="lilei")
test("lilei", age=18)

        4.非固定参数,若你的函数在定义时不确定传入多少个参数,就可以使用非固定参数:*args、**kwargs

def test1(*args):
    print(args)

test1("lilei", 18, "CN")
test1(*["lilei", 18, "CN"])

def test2(**kwargs):
    print(kwargs)
    
test2("Jack",32,"CN","Python",sex="Male",province="ShanDong")


局部变量和全局变量:

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

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

    当全局变量与局部变量同名时:

    在定义局部变量的子程序内,局部变量起作用;在其它地方全局变量起作用。

    其中在子程序中用 关键字 global 定义全局变量。 


递归:

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

def calc(n):
    print(n)
    if int(n/2) ==0:
        return n
    return calc(int(n/2))
 
calc(10)

    递归特性:

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

        2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少

        3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)


本文出自 “学海无涯” 博客,请务必保留此出处http://tofgetu.blog.51cto.com/12856240/1923847

Python基础学习(四)