模块初始
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之间的转换
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,假如有的话就不用变