Python3中类、模块、错误与异常、文件的简易教程


Posted in Python onNovember 20, 2017

和旧版的Python 2.7教程相比,新增内容包括:

  • 新增命名关键字参数的使用;
  • 新增StringIO和BytesIO;
  • 新增datetime的使用;
  • 新增urllib的使用;
  • 新增枚举类型的使用;
  • 新增virtualenv的使用;
  • 新增asyncio编程;
  • 新增aiohttp编程;
  • 实战的Web App已完全基于asyncio重写。

本文将详细给大家介绍Python3中类、模块、错误与异常、文件的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。


面向对象设计思想是 Class 抽象的,Instance 一个个具体的 Class,比如学生是抽象的 Class,而张三李四就是一个个具体学生。

定义

Class 大驼峰命名法。仅供?炔坑玫 Class,名称前会加一个底线。

类定义一般格式:

class Student:
 pass
# 或者
class Developer(object):
 pass

object 表示该类是从哪个类继承下来的,object 是最终的父类。

class Developer(object):
 # 定义类属性
 name = 'WuXiaolong'
 site = 'http://wuxiaolong.me/'
 # 变量名两个下划线开头,定义私有属性, 这样在类外部无法直接进行访问,类的私有方法也是如此
 __sex = 0
 # 定义构造方法
 def __init__(self, name, site, sex):
 self.name = name
 self.site = site
 self.__sex = sex
 # 类方法
 def get_sex(self):
 return self.__sex
 def set_sex(self, sex):
 self.__sex = sex
# 调用:
if __name__ == '__main__':
 # 实例化类
 developer = Developer('wxl', 'http://wuxiaolong.me/', 1) # 实例化成变量
 print(developer.site, developer.get_sex()) # 访问类的属性和方法

注意:以单下划线开头的表示的是 protected 类型的变量或方法,即保护类型,只能允许其本身与子类进行访问,不能用于 from module import *。

单继承

class Developer(object):
 # 定义类属性
 name = 'WuXiaolong'
 site = 'http://wuxiaolong.me/'
 # 变量名两个下划线开头,定义私有属性, 这样在类外部无法直接进行访问,类的私有方法也是如此
 __sex = 0
 # 定义构造方法
 def __init__(self, name, site, sex):
 self.name = name
 self.site = site
 self.__sex = sex
 # 类方法
 def get_sex(self):
 return self.__sex
 def set_sex(self, sex):
 self.__sex = sex
# 单继承
class AndroidCoder(Developer):
 coder_id = 1024
 # 定义构造方法
 def __init__(self, name, site, sex, coder_id):
 # 调用父类构造方法
 # Developer.__init__(self, name, site, sex) # 老办法
 super(AndroidCoder, self).__init__(name, site, sex) # 采用新式
 self.coder_id = coder_id
 # 重写父类的方法
 def set_sex(self, sex):
 self.__sex = sex
 print('这是个秘密')
 def get_sex(self):
 return self.__sex
# 调用:
if __name__ == '__main__':
 # 单继承
 androidCoder = AndroidCoder('wxl', 'http://wuxiaolong.me/', 1, 520)
 print(androidCoder.set_sex(2))

注意:super 继承,要求最顶层的父类一定要继承于object,这样就可以利用 super() 函数来调用父类的 init() 等函数。

多继承

B 继承 A,C 继承 B

以上面的单继承为例,AndroidCoder 继承了 Developer,现在让 PythonCoder 继承 AndroidCoder:

# 多继承,B 继承 A,C 继承 B
class PythonCoder(AndroidCoder):
 # 定义构造方法
 def __init__(self, name, site, sex, coder_id):
 # 调用父类构造方法
 super(PythonCoder, self).__init__(name, site, sex, coder_id)
# 调用:
if __name__ == '__main__':
 pythonCoder = PythonCoder('wxl', 'http://wuxiaolong.me/', 1, 1024)
 print(androidCoder.get_sex())

注意:多继承圆括号中父类的顺序,若是父类中有相同的方法名,而在子类使用时未指定,Python 会调用子类的;

Z 继承 X、Y

class JavaCoder(object):
 java_id = 1
 # 定义构造方法
 def __init__(self, java_id):
 self.java_id = java_id
 print('来自JavaCoder')
class FullStackCoder(AndroidCoder, JavaCoder):
 # 定义构造方法
 def __init__(self, name, site, sex, coder_id):
 # 调用父类构造方法
 super(FullStackCoder, self).__init__(name, site, sex, coder_id)
 JavaCoder.__init__(self, coder_id) # 这里需要使用老办法
# 调用:
if __name__ == '__main__':
 fullStackCoder = FullStackCoder('wxl', 'http://wuxiaolong.me/', 1, 1024)

模块

Python 模块跟 Java 里包概念差不多,使用 import 语句导入。

import 语句

比如在类环节新建的文件名为 wxl_class.py,想在另个文件使用:

## 导入模块
import wxl_class
developer = wxl_class.Developer('wxl', 'http://wuxiaolong.me/', 1) # 实例变量
print(developer.site)

问题:发现打印了两次,原来 wxl_class.py 没有写 __name__ 属性。

__name__ 属性

每个模块都有一个 __name__ 属性,当其值是'__main__'时,表明该模块自身在运行,因此在 wxl_class.py 加上 __main__就好了。

if __name__ == '__main__':
 pass

from…import 语句

从模块导入指定内容或者 * 代表全部:

from wxl_def import hello1
m = hello1(666, 999)

作用域

正常的函数和变量名是公开的(public),可以被直接引用;

以两个下划线开头,定义私有(private), 这样在类外部无法直接进行访问;

以单下划线开头的表示的是 protected 类型的变量,即保护类型只能允许其本身与子类进行访问,不能用于 from module import *。

标准库

Python 本身带着一些标准的模块库,比如 json 模块。

Python3 中可以使用 json 模块来对 JSON 数据进行编解码,它包含了两个函数:

json.dumps(): 对数据进行编码;

json.loads(): 对数据进行解码。

JSON 类型与 Python 类型对应关系:

Python3中类、模块、错误与异常、文件的简易教程

import json
# Python 字典类型转换为 JSON 对象
python_data = {'id': 1024, 'name': 'wxl', 'site': 'http://wuxiaolong.me/'}
print(json.dumps(python_data)) # 打印:{"id": 1024, "name": "wxl", "site": "http://wuxiaolong.me/"}
# 将 JSON 对象转换为 Python 字典
json_data = '{"id": 1024, "name": "wxl", "site": "http://wuxiaolong.me/"}'
print(json.loads(json_data)) # 打印:{'id': 1024, 'name': 'wxl', 'site': 'http://wuxiaolong.me/'}

第三方模块

在 Python 中,安装第三方模块,是通过包管理工具 pip 完成的。

1、安装 pip

sudo easy_install pip

2、比如安装 PyMySQL 模块来连接数据库,Python 3.x:

pip3 install PyMySQL

返回:

Collecting PyMySQL
 Using cached PyMySQL-0.7.11-py2.py3-none-any.whl
Installing collected packages: PyMySQL
Successfully installed PyMySQL-0.7.11

升级 pip 到最新版本

python -m pip install --upgrade pip

错误和异常

Java 中捕获异常是用的 try catch finally,Python 是用的 try…except…finally…:

try:
 name = 'wxl'
 print(int(name))
except ValueError as e: # 所有的错误类型都继承自BaseException
 print(e)
finally:
 print('finally')

文件

Python 内置了读写文件的函数,一般分为 3 步:

1、open() 函数,打开一个文件对象;

2、调用 read() 方法读取文件内容;

3、调用 close() 方法关闭文件。

写文件

桌面新建一个空白 Python3Learn.txt 文件:

def write_file():
 try:
  f = open('/Users/wuxiaolong/Desktop/Python3Learn.txt', 'w') # 标示符'w'表示写
  f.write('Hello, Python')
 except BaseException as e:
  print(e)
 finally:
  if f:
   f.close()

读文件

def read_file():
 try:
  f = open('/Users/wuxiaolong/Desktop/Python3Learn.txt', 'r') # 标示符'r'表示读
  # print(f.read()) # read()会一次性读取文件的全部内容
  print(f.readlines()) # 每次读取一行内容,返回list
 except BaseException as e:
  print(e)
 finally:
  if f:
   f.close()

读取二进制文件

比如图片、视频等等,桌面随便搞张 Python3Learn.png:

def read_byte_file():
 try:
  f = open('/Users/wuxiaolong/Desktop/Python3Learn.png', 'rb') # 标示符'rb'表示读
  print(f.read()) # read()会一次性读取文件的全部内容
  # print(f.readlines()) # 每次读取一行内容,返回list
 except BaseException as e:
  print(e)
 finally:
  if f:
   f.close()

字符编码

encoding 参数:读取非 UTF-8 编码的文本文件;errors 参数:遇到编码错误后如何处理,最简单的方式是直接忽略。

f = open('/Users/wuxiaolong/Desktop/Python3Learn.txt', 'r', encoding='gbk', errors='ignore')

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Python 相关文章推荐
Python 26进制计算实现方法
May 28 Python
Python判断文件和字符串编码类型的实例
Dec 21 Python
Python实现JSON反序列化类对象的示例
Jan 31 Python
Python3实现定时任务的四种方式
Jun 03 Python
django的分页器Paginator 从django中导入类
Jul 25 Python
Django模型修改及数据迁移实现解析
Aug 01 Python
numpy.linalg.eig() 计算矩阵特征向量方式
Nov 29 Python
利用pyshp包给shapefile文件添加字段的实例
Dec 06 Python
使用PyTorch训练一个图像分类器实例
Jan 08 Python
Python PyPDF2模块安装使用解析
Jan 19 Python
使用Python 自动生成 Word 文档的教程
Feb 13 Python
Python实现随机生成迷宫并自动寻路
Jun 13 Python
Python实现将HTML转换成doc格式文件的方法示例
Nov 20 #Python
python中学习K-Means和图片压缩
Nov 20 #Python
深入理解Python中的super()方法
Nov 20 #Python
python实现读取excel写入mysql的小工具详解
Nov 20 #Python
利用selenium 3.7和python3添加cookie模拟登陆的实现
Nov 20 #Python
python Matplotlib画图之调整字体大小的示例
Nov 20 #Python
python cx_Oracle的基础使用方法(连接和增删改查)
Nov 19 #Python
You might like
免费手机号码归属地API查询接口和PHP使用实例分享
2014/04/10 PHP
PHP单例模式详细介绍
2015/07/01 PHP
Laravel框架处理用户的请求操作详解
2019/12/20 PHP
JS BASE64编码 window.atob(), window.btoa()
2021/03/09 Javascript
JavaScript实现的GBK、UTF8字符串实际长度计算函数
2014/08/27 Javascript
jQuery实现可关闭固定于底(顶)部的工具条菜单效果
2015/11/06 Javascript
原生JS实现风箱式demo,并封装了一个运动框架(实例代码)
2016/07/22 Javascript
jQuery+css实现非常漂亮的水平导航菜单效果
2016/07/27 Javascript
js 转json格式的字符串为对象或数组(前后台)的方法
2016/11/02 Javascript
Bootstrap的基本应用要点浅析
2016/12/19 Javascript
JS匹配日期和时间的正则表达式示例
2017/05/12 Javascript
微信小程序url传参写变量的方法
2018/08/09 Javascript
从源码里了解vue中的nextTick的使用
2018/11/22 Javascript
jQuery实现网页拼图游戏
2020/04/22 jQuery
详解nodejs解压版安装和配置(带有搭建前端项目脚手架)
2018/12/06 NodeJs
js如何获取图片url的Blob值并预览示例代码
2019/03/07 Javascript
详解nodejs http请求相关总结
2019/03/31 NodeJs
vue2路由方式--嵌套路由实现方法分析
2020/03/06 Javascript
Python 编码处理-str与Unicode的区别
2016/09/06 Python
Python实现分段线性插值
2018/12/17 Python
Python3.5 Pandas模块之Series用法实例分析
2019/04/23 Python
Python中的类与类型示例详解
2019/07/10 Python
Django REST framework 视图和路由详解
2019/07/19 Python
简单了解python数组的基本操作
2019/11/26 Python
python数据预处理方式 :数据降维
2020/02/24 Python
python GUI库图形界面开发之PyQt5打开保存对话框QFileDialog详细使用方法与实例
2020/02/27 Python
python不到50行代码完成了多张excel合并的实现示例
2020/05/28 Python
终于搞懂了Keras中multiloss的对应关系介绍
2020/06/22 Python
使用darknet框架的imagenet数据分类预训练操作
2020/07/07 Python
调用HTML5的Canvas API绘制图形的快速入门指南
2016/06/17 HTML / CSS
Piercing Pagoda官网:耳环、戒指、项链、手链等
2020/09/28 全球购物
机电一体化专业应届生求职信
2013/11/27 职场文书
怎么写自荐书范文
2014/02/12 职场文书
优秀安全员事迹材料
2014/05/11 职场文书
小区门卫的岗位职责
2014/09/26 职场文书
2015年办公室文秘工作总结
2015/04/30 职场文书