python异常处理及内置模块
异常处理
有时候我们在写程序的时候会出现错误或者异常,导致程序终止,如下这个例子:
#!/usr/bin/env python
a = 2/0
print(a)
结果提示如下错误:
Traceback (most recent call last):
File "002.py", line 2, in <module>
a = 2/0
ZeroDivisionError: integer division or modulo by zero
上面提示被除数不能为0,从而导致程序运行中断,为了能够让程序正常执行,我们可以添加tey...except...
语句:
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
try:
a = 2/0
print(a)
except Exception as e:
print("除数不能为0")
#raise e # 把异常抛出来
finally:
print("无论发生什么情况,都执行此步。")
结果:
除数不能为0
无论发生什么情况,都执行此步。
上面如果加上了raise e,则会把异常信息打印出来:ZeroDivisionError: integer division or modulo by
zero。其中except部分是对错误信息进行处理,finally是不管之前有没有异常,都会执行此步骤。
python标准异常类:
模块
模块和目录的区别,看整个文件夹里面是否有__init__.py
文件,有就是模块,没有就是普通目录。__init__.py
一般是一个空文件。
通常一个.py文件我们就可以称之为一个模块。
a.py
#!/usr/bin/env python
def hello():
print("hello")
hello()
def world():
print("world")
world()
b.py
#!/usr/bin/env python
import a
运行python b.py结果:
hello
world
如上 ,当我们在b.py中将a.py作为模块导入之后,在运行b.py的时候,直接会运行a.py里面的所有函数,但是如果我们只想要在b.py中调用a.py中指定函数的时候运行,就需要在a.py中加入if __name__ == "__main__":
语句:
a.py
#!/usr/bin/env python
def hello():
print("hello")
def world():
print("world")
if __name__ == "__main__":
hello()
world()
b.py
#!/usr/bin/env python
import a
a.hello()
a.world()
运行python b.py之后的结果:
hello
world
由上可以看出,加上if __name__ == "__main__":
语句之后,就能满足我们的需求。
总结:
1、文件夹里面需要有__init__.py
文件的才能当做模块使用。
2、if __name__ == "__main__":
语句的使用。
内置模块
datetime
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import datetime
# 下面我们使用的是datetime模块下面的datetime模块,所以使用的时候需要datetime.datetime,为了更方便的使用,也可以直接使用from datetime import datetime
print(datetime.datetime.now()) # 打印当前时间 2018-04-23 09:33:32.055974
print(datetime.datetime.now().year) # 打印当前时间中的年份 2018
print(datetime.datetime.now().month) # 打印当前时间中的月份 4
print(datetime.datetime.now().day) # 打印当前时间中的天 23
print(datetime.datetime.now().hour) # 打印当前时间中的小时 9
print(datetime.datetime.now().minute) # 打印当前时间中的分钟 33
print(datetime.datetime.now().second) # 打印当前时间中的秒 32
print(datetime.datetime.now().microsecond) # 打印当前时间中的毫秒 56063
print(datetime.datetime.now().strftime("%Y-%m-%d")) # 从时间格式转换成字符串,满足"%Y-%m-%d"格式的字符串格式 2018-04-23 09:33:32.055974 --> 2018-04-23
print(datetime.datetime.now().strftime("%c")) # 标准时间,类似于这种格式 Mon Apr 23 09:50:45 2018
print(datetime.datetime.now().strftime("%a")) # 本地简化星期名称 Mon
print(datetime.datetime.now().strftime("%b")) # 本地简化月份名称 Apr
print(datetime.datetime.now().strftime("%d")) # 当前这天是一个月中的第几天 23
# 直接导入datetime模块下面的datetime
#from datetime import datetime
#print(datetime.now())
%Y 带世纪部分的十进制年份
%m 十进制表示的月份
%d 十进制表示的每月的第几天
%H 24小时制的小时
%M 十进制表示的分钟数
%S 十进制的秒数
如果我们需要表示昨天、上周等情况:
#!/usr/bin/env python
from datetime import datetime
from datetime import timedelta
now_time = datetime.now() # 当前时间
print(now_time)
b = now_time + timedelta(days = -1) # 一天前
print(b)
c = now_time + timedelta(days = -1,weeks = -1) # 一个周前的前一天
print(c)
结果:
2018-04-23 10:35:40.245370
2018-04-22 10:35:40.245370
2018-04-15 10:35:40.245370
time模块
这个time模块不是datetime下面的那个模块,它是一个单独的模块。
#!/usr/bin/env python
import time
time.sleep(2) # 暂停2秒后,打印
print("Hello")
print(time.time()) # 打印时间戳,即从1970-01-01到现在的秒数
print(time.localtime())
# time.struct_time(tm_year=2018, tm_mon=4, tm_mday=23, tm_hour=10, tm_min=47, tm_sec=59, tm_wday=0, tm_yday=113, tm_isdst=0)
time.strptime(string,[,format]) # 把一个格式化时间字符串转化为struct_time,它和strftime是逆操作。
commands模块
有时候我们需要使用shell命令,就用到了commands模块。
'''
遇到问题没人解答?小编创建了一个Python学习交流QQ群:778463939
寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书!
'''
import commands
output = commands.getoutput("ls -ll") # 返回执行完命令后的结果
print(output)
status, output = commands.getstatusoutput("ls -l") # 返回一个元组,如果shell执行成功,第一个值(状态码)是0表示成功,第二个值是shell执行结果
print(status,output)
subprocess模块
和commands模块用法类似,都是用来执行shell命令的。
#!/usr/bin/env python
from subprocess import PIPE,Popen
p = Popen(['ifconfig'],stdout=PIPE)
data = p.stdout.read()
print(data)