wk_10.md

Python检测和处理异常

try-except语句

try-except语句定义了进行异常监控的一段代码,并且提供了异常处理的机制,下面是使用的语法:

try:
    # 可能抛出异常的语句,会一直执行,直到抛出异常。
except:
    # 异常处理额语句,当try快任意语句抛出异常时执行。

当try中执行的语句没有抛出异常则except中的语句是不会执行的:

try:
    print(float(23232))
    print(‘********‘)
except:
    print(‘except‘)
输出:
23232.0
********

当try中语句有多个时一旦执行到错误或异常的语句之后就是执行except中的语句并退出程序,而try中没有执行的语句则不会在被执行:

try:
    print(float(23232))
    print(‘********‘)
    print(float(‘dota‘))
    print(‘-------‘)
except:
    print(‘except‘)
输出:
23232.0
********
except

在try中定义的变量是可以在except中使用的:

try:
    a=‘DOTA‘
    print(a)
    print(float(a))
except:
    print(‘except‘,a)
输出:
DOTA
except DOTA

通过制定类型对不同的异常做不同的处理:

try:
    float(‘aaaa‘)
except ValueError as e:
    print(‘aaaa value error. {}‘.format(e))
except NameError as e:
    print(‘aaaa name error. {}‘.format(e))
except Exception:
    print(‘error‘)
except:
    print(‘......‘)
输出:
aaaa value error. could not convert string to float: ‘aaaa‘
  • 异常语句从上往下执行,匹配到哪一条执行该条语句并停止匹配。
  • 如果Exception放在最上面则下面的具体性异常ValueError或者NameError是不会执行的。
  • 通常会把具体的异常放到上面,一般性的异常放到下面。
  • 当不带任何模式的时候,相当于default分支,会捕获所有未捕获的异常。

finally 子句

  • finally 语句总是会被执行,无论有没有抛出异常。所有的清理工作通常放到finally语句块里执行。
  • finally 在return 语句之后,函数返回之前执行。通常使用中不会再finally 里return。
def fn():
    try:
        1 / 0
        print(‘try‘)
        return 1
    except:
        print(‘except‘)
        return 2
    finally:
        print(‘finally‘)
        return 3
    print(‘fn‘)
    return 4

print(fn())
输出:
except
finally
3

自定义异常

  • 自定义异常需要我们自己抛出,使用raise语句抛出。
  • raise 语句后面只能跟一个异常的实例。
class UserException(Exception):
    pass

class SystemException(Exception):
    pass

def div(x,y):
    try:
        return x/y
    except ZeroDivisionError:
        raise UserException(‘y must no be zero‘)

try:
    div(5,0)
except UserException as e:
    print(e)
except SystemException as e:
    pass
输出:
y must no be zero

在实际的编码中,我们应该在哪一层处理异常:

  • 通常在endpoint (指的一个边界)处处理异常。
  • 有替代方案时立即处理异常。使用替代方案。
  • 异常做为业务逻辑,不推荐使用。
  • 异常可以忽略。
  • 异常需要延后处理,需要立即处理,并暂存异常,以便延后处理。

导入模块

import 语句

import 语句用于导入模块,当模块导入后,就可以以模块名为命名空间,使用模块的变量,函数和类了。

In [1]: import os

In [3]: os.getcwd()
Out[3]: ‘/root‘

from import 语句

可以把模块中指定的成员导入如到当前作用域,这就是部分导入,这种导入的命名空间也是部分的。

In [5]: from os import path

In [8]: path.basename(‘/tmp‘)
Out[8]: ‘tmp‘

In [9]: os.cpu_count()
Out[9]: 1

In [10]: from os import cpu_count

In [11]: cpu_count()
Out[11]: 1

扩展的 import 语句(as)

当我们导入模块的名称重复或者名称过长的时候就可以使用as 来进行重命名。

In [15]: from posix import stat_result as posix_stat_result

In [16]: from os import stat_result as os_stat_result

模块搜索路径

如果不做特殊修改,在用import导入模块是路径的先后顺序如下:当前目录-->标准库-->第三方库。

In [17]: import sys

In [18]: for path in sys.path:
   ....:     print(path)
   ....:     

/root/.pyenv/versions/3.5.2/envs/pengfei/bin
/root/.pyenv/versions/3.5.2/lib/python35.zip
/root/.pyenv/versions/3.5.2/lib/python3.5
/root/.pyenv/versions/3.5.2/lib/python3.5/plat-linux
/root/.pyenv/versions/3.5.2/lib/python3.5/lib-dynload
/root/.pyenv/versions/3.5.2/envs/pengfei/lib/python3.5/site-packages
/root/.pyenv/versions/3.5.2/envs/pengfei/lib/python3.5/site-packages/IPython/extensions
/root/.ipython

由于python默认第一是从当前目录进行导入模块,所以一旦当前路径的模块名和系统模块名重名则不会导入系统模块。

包是一个有层次的文件目录结构,它定义了一个由模块和子包组成的Python应用程序执行环境。

  1. 一个目录下有__init__.py的时候,这个目录是一个模块(包),模块的内容写在__init__.py
  2. 这个目录下的其他文件,是这个模块的子模块。
  3. 导入子模块的时候会先导入父模块。
  4. 导入父模块不会自动导入子模块。
  5. 子模块可以使用from parent import child这样的形式导入,也可以使用import parent,child
  6. import parent.child这种导入方式,child必须是子模块。
  7. 同一模块下的子模块,可以使用相对导入,也可以使用绝对导入。
时间: 2024-09-29 12:29:45

wk_10.md的相关文章

GitHub上README.md教程

转自:http://blog.csdn.net/kaitiren/article/details/38513715#t0 最近对它的README.md文件颇为感兴趣.便写下这贴,帮助更多的还不会编写README文件的同学们. README文件后缀名为md.md是markdown的缩写,markdown是一种编辑博客的语言.用惯了可视化的博客编辑器(比如CSDN博客,囧),这种编程式的博客编辑方案着实让人眼前一亮.不过GitHub支持的语法在标准markdown语法的基础上做了修改,称为Githu

MD、EVA、PU、PVC、TPU、DPU

RB.PU.PVC.TPU.TPR.TR, EVA .MD . DPU DPU是一种耐磨.韧性好的工程塑料,不比EVA或橡胶底或牛筋底差,但其质量比以上都轻,但易刺破不易攀岩 1.先说什么是MD:MODEL或PHYLON飞龙的统称 2.那么什么是PHYLON:(俗称飞龙)是一种做鞋底的材料一般制鞋用的中底, 用加热压缩的EVA发泡制成的混合物质.(属EVA二次高压成型品)特点质轻, 弹性及抗震性能好, 硬度是由发泡温度控制的. 3.那么什么是EVA:Ethylene Vinyl Acetate-

(转)VC运行库MD /MDd /MT /MTd /ML /MLd

VC编译选项 - 多线程(/MT) - 多线程调试 (/MTd) - 多线程DLL (/MD) - 多线程调试DLL (/MDd) C 运行时库 库文件 - Single thread(static link) ML libc.lib - Debug single thread(static link) MLd libcd.lib - MultiThread(static link) MT libcmt.lib - Debug multiThread(static link) MTd libcm

README.md文件 github Markdown语言详解 md文件用法和说明

本人使用.md文档完全为了记录日常的编译和工作中遇到的问题,需要用到的功能大概就是常用的语法,强调,引用,代码,链接等.对于图片的插入需求不高,因此本文主要介绍一些语法特点,最后涉及一点可能用到的其他功能. 000-->功能函数详细条目: 区块元素 段落和换行 一个 Markdown 段落是由一个或多个连续的文本行组成,它的前后要有一个以上的空行(空行的定义是显示上看起来像是空的,便会被视为空行.比方说,若某一行只包含空格和制表符,则该行也会被视为空行).普通段落不该用空格或制表符来缩进. 「由

如何在MD(d)和MT(d)工程间正确分配和释放动态内存

MD(d)和MT(d) MD(d)和MT(d)是windows下VC开发的两个编译选项,表示程序的运行时库编译选项. /MT是"multithread, static version" 意思是多线程静态的版本,定义了它后,编译器把LIBCMT.lib安置到OBJ文件中,让链接器使用LIBCMT.lib 处理外部符号. /MD是"multithread- and DLL-specific version",意思是多线程DLL版本,定义了它后,编译器把MSVCRT.li

Markdown语法学习(Github/git.oschina.net上README.md书写规范)(转)

晚上在更新git.oschina.net项目时,突然想知道README.md后缀的来源,于是搜了下,发现README.md使用了一种小标记语言Markdown的语法,于是简单的看了一个,特转载如下,为了下次参考方便(http://blog.csdn.net/kaitiren/article/details/38513715也不错).中文参考手册可以参考http://wowubuntu.com/markdown/index.html Markdown 的目标是实现「易读易写」,兼容HTML. 但是

.md即markdown文件的基本常用编写语法(图文并茂)

序言: 很久没有写博客了,感觉只要是不写博客,人就很变得很懒,学的知识点感觉还是记不住,渐渐地让我明白,看的越多,懂的越少(你这话不是有毛病吗?应该是看的越多,懂的越多才对),此话怎讲,当你在茫茫的前端知识库里面东看看,西看看的时候,很快就被海量的知识给淹没了,根本就不知道哪些是对的,哪些是错的,感觉好像这个也懂了,那个也懂了,但是真正写起来,脑子又一片空白,又好像什么都不懂,这种状态时有发生,这就叫不懂装懂,最根本的原因就是看的太多,写的太少,所以为了改掉这样毛病,把被动学习变成主动学习,接下

VS运行时 /MD、/MDd 和 /MT、/MTd之间的区别

程序运行时出现问题,选择的是Release,win64位的模式,并且已经看到了宏定义NDEBUG,但是程序依然进入上面的部分 解决方案是将属性->C/C++->代码生成器->运行库里面的多线程调试(/MTD)修改为多线程DLL(/MD)即可 修改之后: 编译一下 解释原因来自 http://blog.csdn.net/u013829933/article/details/50321355,感谢~~ 这里总结下他们的区别,后面的那个'd'是代表DEBUG版本,没有'd'的就是RELEASE

关于github中的README.md文件

0x01 README.md文件是用Markdown语言编写的,md=Markdown; 在线编辑工具: https://stackedit.io/editor# https://maxiang.io/#笔记本和标签 关于使用语法的说明: https://github.com/guoyunsky/Markdown-Chinese-Demo 0x02 Markdown 是一种轻量级的「标记语言」,它的优点很多,目前也被越来越多的写作爱好者,撰稿者广泛使用.看到这里请不要被「标记」.「语言」所迷惑,