欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Python的基础学习(第二周)

程序员文章站 2022-05-11 17:21:18
模块初始 sys模块 import sys sys.path #打印环境变量 sys.argv#打印该文件路径 #注意:该文件名字不能跟导入模块名字相同 os模块 import os cmd_res = os.system("dir")#只执行system命令,不保存结果,返回一个值0代表执行成功, ......

模块初始

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,假如有的话就不用变