Python的基础学习(第二周)

模块初始

sys模块

import sys

sys.path #打印环境变量

sys.argv#打印该文件路径

#注意:该文件名字不能跟导入模块名字相同

os模块

import os

cmd_res = os.system("dir")#只执行system命令,不保存结果,返回一个值0代表执行成功,1代表执行失败

cmd_res = os.popen("dir).read()#执行system命令并且保存结果

os.mkdir("new_dir")#创建一个新的目录

第三方库模块

用户可以自己编写自己所需要的模块来进行调用

.pyc是什么

当python程序运行时,编译的结果则是保存在内存中的PyCodeObject中,PyCodeObject则是Python编译器真正编译成的结果,当Python程序结束运行时,Python解释器则将PyCodeObject写到pyc文件中。当python程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如果找到则直接进去,否则就重复上面的过程。因此Python其实是一门先编译后解释的语言。

Python的三元运算

b = a if xxx else c

相当于c++中b = xxx?a:c

Python的str与bytes之间的转换

Python的基础学习(第二周)

msg.encode(encoding = "utf-8")

msg,decode(encoding = "utf-8")

Python列表的学习

Python列表的格式

names = ["ZhangSan", "LiSi", "WangWu"]

Python的增

names.append("ZhaoLiu")加到后面

names.insert(1, "ls")把ls插到”LiSi”前面

Python的删

names.remove("ZhanSan")

del names[0]

names. pop[0] 默认为最后一个

Python的改

names[0] = "ls"

Python的查

names.index("ZhangSan")  该字符串所在的下表

names[0] 取第一个列表中的元素

names[0:2] --》names[:2] 取names[0], names[1]包括左边不包括右边

names[-1]取最后一个元素

names[-2:]取最后两个值

Python其他的函数

names.count("ZhangSan") 该字符串的数量

names.clear()清空列表

names.reverse()列表进行反转

names.sort()列表排序

extend用法

names2 = [1, 2, 3]

names.extend(names2)

names = ["ZhangSan", "LiSi", "WangWu", 1, 2, 3]

Python的copy函数

浅拷贝

names = ["a", "b", "c", "d"]

names2 = names.copy()

names[1] = "B"

-->names = ["a", "B", "c", "d"]

--> names2 = ["a", "b", "c", "d"]

names = ["a", "b", "c", [1, 2 ,3],  "d"]

names2 = names.copy()

names[3][0] = 10

-->names = ["a", "b", "c", [10, 2 ,3],  "d"]

-->names = ["a", "b", "c", [10, 2 ,3],  "d"]

由此可以看出copy为浅拷贝,只拷贝第一层,也就是说只拷贝了内存地址(引用)

深拷贝

import copy

names2 = copy.deepcopy(names)

列表的循环

names = ["a", "b", "c", "d"]

for i in names[0:-1:2]:

  print(i)

-->['a', ' c']

for k, v in enumerate(names):

  print(i, k)

-->0 a

1 b

2 c

3 d

Python元组的学习

元组跟列表差不多,只不过它一旦创建,便不能在进行修改,所以又叫只读列表

写法:names = ("a", "b", "c")

Python的字符串的一些操作

names = "my name is jason!"

names.capitalize()  -->My Name Is Jason! 首字符大写

names.count("a")   -->2 a的个数

names.center(20, "-") -->--------My Name Is Jason!----------打印20个字符不够用-来,字符串放中间

names.endswith("on!") -->True 字符串是否以什么结尾

names2 = "my \tname is jason!"

names2.expandtabs(tabsize = 20)  -->my   name is jason!

names.find("names")    -->4 查找第一个出现的字符串

names3 = "my name is{_name}, i am {_age}!"

names3 .format(_name= "Jason", _age= 24)

-->my name is Jason, i am 24!

names.isalnum()  是否是阿拉伯数字

names.isalpha()   是否是字符

names.isdecimal()    是否是十进制

names.isdigit()   是否是整数

names.isidentifier() 是否是合法字符

names.isnumeric() 是否是数字(只有数字,不能有.)

等等

Python的字典操作

python的数据类型key_value相当于lua中的table,c++中的map

字典的写法

info_dic = {

  "a":"广州",

  “b”:"香港",

  “c”:“澳门”,

}

字典的特性

dict是无序的,每次输出的结果都可能不一样

key必须是唯一的

info_dic = {

  "a":"广州",

  “b”:"香港",

  “c”:“澳门”,

}

字典的增

a["e"] = "北京 "

字典的删

del info_dic["a"]

info_dic.pop("a")

info_dic.popitem() 随机删除

字典的改

info_dic["a"] = "上海"

字典的查

info_dic["a"] 当不存在就会报错

info_dic.get("a”) 不存在就会返回None

字典可以多级嵌套,也可以嵌套列表

字典的其他函数用法

info_dic.values() -->["a", "b", "c"]

info_dic.keys() -->["广州", "香港", "澳门"]

info_dic.setdefault("d", "大连") 创建一个新的值,前提是字典中没有这个key,假如有的话就不用变

上一篇:MySQL实现类似Oracle的序列


下一篇:Enterprise Achitect使用与类的关系的简单介绍