Python
2019-03-01 本文已影响5人
ienos
有趣的开始
import this
print 打印
字符串 %s / 数字 %d / 不确定类型 %r
print("hello world!")
print("hello %s, Nice to meet you" %name)
input 接受用户输入获取信息
n = input("Enter any content:")
单引号、双引号可以互相嵌套使用,但不能交叉使用
注释
# 单行注释
"""
双引号多行注释
"""
'''
单引号多行注释
'''
分支和循环
- 条件判断
if a > b :
else:
- 包含关系
hello = 'hello'
if hello in hw :
print('包含')
else:
print('不包含')
- 布尔类型
a = True
if a:
else:
- 多重条件
if results >= 90 :
elif results >= 70 :
else:
- for 语句
for i in "hello world" :
print(i)
for i in range(5) :
print(i)
# 设置起始和结束位置,以及步长
for i in range(1, 10, 2) :
print(i)
数组
- [1, 2]
- append()函数可以向数组末尾追加新的项
字典
- dicts = { key: value, key1: value1 }
- dicts.keys()
- dicts.values()
- dicts.items() // 无序
# 有序处理 , zip 合并 Array 为 Dictionary
keys = ["b", "a", "c", "e", "d"]
values = ["2", "1", "3", "5", "4"]
for key, value in zip(keys, values) :
print(key, value)
函数、类和方法
- 函数
def add(a, b):
print(a + b)
add(3, 5)
# 默认值
def add(a=1, b=2):
return a + b
add()
- 类和方法
class A(object):
def add(self, a, b):
return a + b
count = A()
print(count.add(3, 5))
# 初始化方法
classA():
def __init__(self, a, b):
self.a = int(a)
self.b = int(b)
def add(self):
return self.a + self.b
count = A('4', 5)
print(count.add())
# 继承
class A():
def add(self, a, b):
return a + b
class B(A):
def sub(self, a, b):
return a - b
print(B().add(4, 5))
模组:类库、模块
- 引用模块 :import / from ... import ...
- 获取当前时间:from time import ctime 调用 ctime()
- 获取详细:help(time)
- 模块下面所有方法:from time import *
模块调用
- 同个目录下多个文件: from file import func
- 跨目录访问文件:from model.pub import add (Python3)
import 的过程
- 创建一个 new module 对象(可能包含多个 module)
- 把 module 对象插到 sys.module 中
- 装载 module 的代码(如果需要,则必须先编译)
- 执行新的 module 中对应的代码
找到对应的代码过程:当前路径、然后再是 Python 安装时设置的相关默认路径。如果当前路径的 module 与系统一致,则会覆盖系统 module
python2 处理方法
- model 目录下有 new_count.py / count.py
- model 同级目录下有 test.py
- test.py 调用 new_count 的方法,new_count 方法的实现调用 count 方法
- test.py 下 from model import new_count.py
- 运行报错,因为 new_count.py 下 from count import A,test.py 此时找不到 count
添加目录到系统环境变量到 test.py 下
import sys
# 将 model 目录添加到系统环境变量 path 下
sys.path.append("./model")
# 如果使用 Python2 需要在该目录下创建一个 __init.py 文件(文件内容可以为空),用来标识这是一个标准包含 Python 模块的目录
异常
异常类:Exception(继承 BaseException) / BaseException(Python 2.5+)
try
# r 只读,打开文件
open("abc.txt", "r")
except FileNotFoundError:
print("异常了!")
- 解释器会查找相应的处理语句,例如:FileNotFoundError / NameError
- 如果在当前函数没有找到的话,传递给上层调用函数,如果最外层还没有找到的话,就会退出,同时打印 Traceback
获取异常原因
try:
open("abc.txt", 'r')
print(aa)
except BaseException as msg:
print(msg)
异常处理
异常 | 描述 |
---|---|
BaseException | 新的所有异常类的基类 |
Exception | 所有异常类的基类,但继承 BaseException 类 |
AssertionError | assert 语句失败 |
FileNotFoundError | 试图打开一个不存在的文件或目录 |
AttributeError | 试图访问的对象没有属性 |
OSError | 当系统函数返回一个系统相关的错误,包括 I/O 故障,如 “找不到文件” 或 “磁盘已满” 时,引发此异常 |
NameError | 使用一个还未赋值对象的变量 |
IndexError | 当一个序列超出了范围 |
SynateError | 当解析器遇到一个语法错误时引发 |
KeyboardInterrupt | Ctrl+C 被按下,程序被强行终止 |
TypeError | 传入的对象类型与要求不符 |
else 没有异常时执行
try:
aa = “异常测试:”
print(aa)
except Exception as msg:
print(msg)
else:
print("没有异常!")
finally 不管有没有异常都会执行
try:
print(aa)
except Exception as e:
print(e)
finally:
print("不管是否异常,我都会被执行")
抛出异常
# 生成随机数
from random import randint
# 生成 1~9 的随机数
number = randint(1, 9)
# 抛出异常,只能抛出 Python 所提供的异常类,自定义类不能抛出
raise NameError("1 is odd 9 number")