Python基础学习笔记(三)
第九章
了解异常
- 当检测到一个错误时,Python解释器就无法继续执行了,反而出现了一些错误的提示,这就是所谓的“异常”,也就是我们常说的BUG
异常的捕获
- 为什么需要捕获异常?
当我们的程序遇到了BUG,那么接下来有两种情况:
- 整个程序因为一个BUG停止运行
- 对BUG进行提醒,整个程序继续运行
- 显然在之前的学习中,我们所有的程序遇到BUG就会出现1的这种情况,也就是整个程序直接奔溃.但是在真实工作中,我们肯定不能因为一个小的BUG就让整个程序全部奔溃,也就是我们希望的是达到2的这种情况那这里我们就需要使用到捕获异常
- 捕获异常的作用在于:提前假设某处会出现异常,做好提前准备,当真的出现异常的时候,可以有后续手段。
1 | # try:可能发生错误的代码 |
异常的传递性
- 异常是具有传递性:
当函数func01中发生异常,并且没有捕获处理这个异常的时候,异常会传递到函数func02,当func02也没有捕获处理这个异常的时候main函数会捕获这个异常,这就是异常的传递性. - 提示:当所有函数都没有捕获异常的时候,程序就会报错
1 | # 定义一个出现异常的方法 |
模块的概念和导入
Python 模块(Module),是一个Python文件,以.py结尾. 模块能定义函数,类和变量,模块里也能包含可执行的代码.
模块的作用:python中有很多各种不同的模块,每一个模块都可以帮助我们快速的实现一些功能,比如实现和时间相关的功能就可以使用time模块我们可以认为一个模块就是一个工具包,每一个工具包中都有各种不同的工具供我们使用进而实现各种不同的功能.
1
2
3
4
5
6
7# [from 模块名] import [模块 | 类 | 变量 | 函数 *] [as 别名]
# import模块名-案例
#使用import导入time模块使用sLeep功能(函数)
import time # 导入Python内置的time模块(time.py这个代码文件)
print("你好")
time.sleep(5) # 通过,就可以使用模块内部的全部功能(类、函数、变量)
print("我好")1
2
3
4
5# 使用from号入time的sLeep功能(函数)
from time import sleep
print("你好")
sleep(5)
print("我好")1
2
3
4
5
6# 使用*导入time模块的全部功能
from time import * # *表示全部的意思
print("你好")
sleep(5)
print("我好")1
2
3
4
5# 使用as给特定功能加上别名
import time as t
print("你好")
t.sleep(5)
print("我好")
自定义模块并导入
- 案例:新建一个Python文件,命名为my_modulel.py,并定义test函数
1
2
3
4# 导入自定义模块使用
# import my_module1
from my_module1 import test
test(1,2)
- 如何自定义模块并导入?
在Python代码文件中正常写代码即可,通过import、from关键字和导入Python内置模块一样导入即可使用。 - _main_变量的功能是?
if_main_== "_main_"
表示,只有当程序是直接执行的才会进入if内部,如果是被导入的,则if无法进入
- 注意事项:不同模块,同名的功能,如果都被导入,那么后导入的会覆盖先导入的
_all_变量可以控制import*的时候哪些功能可以被导入
自定义Python包
- 从物理上看,包就是一个文件夹,在该文件夹下包含了一个 init.py文件,该文件夹可用于包含多个模块文件
- 从逻辑上看,包的本质依然是模块
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23# 演示Python的包
# 创建一个包
# 导入自定义的包中的模块,并使用
# import my_package.my_module1
# import my_package.my_module2
# my_package.my_modulel.info_print1()
# my_package.my_module2.info_print2()
# from my_package import my_module1
# from my_package import my_module2
# my_modulel.info_print1()
# my_module2.info_print2()
# from my_package.my_modulel import info_print1
# from my_package.my_module2 import info_print2
# info_print1()
# info_print2()
# 通过__all__变量,控制import *
from my_package import *
my_modulel.info_print1()
# my_module2.info_print2() 只引用了my_moudle1,因此该行不被调用
安装第三方包
- 在Python程序的生态中,有许多非常多的第三方包(非Python官方),可以极大的帮助我们提高开发效率,如:
- 科学计算中常用的:numpy包
- 数据分析中常用的:pandas包
- 大数据计算中常用的:pyspark、apache-flink包
- 图形可视化常用的:matplotlib、pyecharts
- 人工智能常用的:tensorflow等
- pip install xxx
第十章
JSON数据格式的转换
- JSON是一种轻量级的数据交互格式。可以按照JSON指定的格式去组织和封装数据
- JSON本质上是一个带有特定格式的字符串
- 主要功能: json就是一种在各个编程语言中流通的数据格式,负责不同编程语言中的数据传递和交互.(类python的字典)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24import json
# 准备列表,列表内每一个元素都是字典,将其转换为JSON
data = [{"name":"张大山","age": 11},{"name":"王大锤","age": 13},{"name":"赵小虎","age": 16}]
json_str = json.dumps(data, ensure_ascii=False) # ensure_ascii=False中文显示
print(type(json_str))
print(json_str)
# 准备字典,将字典转换为JSON
d = {"name":"周杰轮","addr":"台北"}
json_str = json.dumps(d, ensure_ascii=False)
print(type(json_str))
print(json_str)
# 将JSON字符串转换为Python数据类型[{k:v,k: v,{k:v,k: v}]
s = '[{"name":"张大山","age": 11},{"name":"王大锤","age": 13},{"name":"赵小虎","age": 16}]'
l = json.loads(s)
print(type(l))
print(l)
# JSON宇符申转换为Python数据类型{k: v,k: v}
s = '{"name": "周杰轮","addr": "台北"}'
d = json.loads(s)
print(type(d))
print(d) - JSON可以直接和Python的字典或列表进行无缝转换
pyecharts模块简介
概况:Echarts 是个由百度开源的数据可视化,凭借着良好的交互性,精巧的图表设计,得到了众多开发者的认可.而 Python 是门富有表达力的语言,很适合用于数据处理.当数据分析遇上数据可视化时pyecharts 诞生了
如何安装PyEcharts包:
pip install pyecharts
如何查看官方示例
打开官方画廊:
https://gallery.pyecharts.org/#/README
pyecharts的入门使用
- 全局配置项能做什么?
配置图表的标题,配置图例,配置鼠标移动效果,配置工具栏等整体配置项1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19# 导包
from pyecharts.charts import Line
from pyecharts.options import TitleOpts, LegendOpts, ToolboxOpts, VisualMapOpts
# 创建一个折线图对象
line = Line()
# 给折线图对象添加x轴的数据
line.add_xaxis(["中国","美国","英国"])
# 给折线图对象添加y轴的数据
line.add_yaxis("GDP", [30,20,10])
# 设置全局配置项set_global_opts来设置,
line.set_global_opts(
title_opts=TitleOpts(title="GDP展示", pos_left="center", pos_bottom="1%"),
legend_opts=LegendOpts(is_show=True),
toolbox_opts=ToolboxOpts(is_show=True),
visualmap_opts=VisualMapOpts(is_show=True),
)
# 通过render方法,将代码生成为图像
line.render() - 复制代码,运行后,同一文件夹下生成html文件
数据准备/生成折线图
1 | import json |
第十一章
数据可视化案例-全国疫情地图构建
1 | # 演示全国疫情可视化地图开发 |
河南省疫情地图绘制
1 | # 演示河南省疫情地图开发 |
动态GDP柱状图绘制
- Timeline ()-时间线
柱状图描述的是分类数据,回答的是每一个分类中了有多少?] 这个问题,这是柱状图的主要特点,同时柱状图很难动态的描述个趋势性的数据.这里pyecharts为我们提供了一种解决方案-时间线1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70# 演示第三个图表:GDP动态柱状图开发
from pyecharts.charts import Bar, Timeline
from pyecharts.options import *
from pyecharts.globals import ThemeType
# 读取数据
f = open("F:\Code\python\可视化案例数据\动态柱状图数据\GDP.csv", "r", encoding="GB2312")
data_lines = f.readlines()
# 关闭文件
f.close()
# 删除第一条数据
data_lines.pop(0)
# 将数据转换为字典存储,格式为:
# { 年份:[[国家,gdp],[国家,gdp],......],年份: [[国家,gdp],[国家,gdp],......],......}
#[ 1960:[[美国,123],[中国,321],......],1961:[[美国,123],[中国,321],...... ],......}
# 先定义一个字典对象
data_dict = {}
for line in data_lines:
year = int(line.split(",")[0]) # 年份
country = line.split(",")[1] # 国家
gdp = float(line.split(",")[2]) # GDP数据
# 如何判断字典里面有没有指定的key呢?
try:
data_dict[year].append([country, gdp])
except KeyError:
data_dict[year] =[]
data_dict[year].append([country, gdp])
# print(data_dict[1960])
# 创建时间线对象
timeline = Timeline({"theme": ThemeType.LIGHT})
# 排序年份
sorted_year_list = sorted(data_dict.keys())
for year in sorted_year_list:
data_dict[year].sort(key=lambda element: element[1], reverse=True)
# 取出本年份前8名的国家
year_data = data_dict[year][0:8]
x_data = []
y_data = []
for country_gdp in year_data:
x_data.append(country_gdp[0]) # x轴添加国家
y_data.append(country_gdp[1] / 100000000) # y轴添加gdp数据
#构建柱状图
bar = Bar()
x_data.reverse()
y_data.reverse()
bar.add_xaxis(x_data)
bar.add_yaxis("GDP(亿)", y_data, label_opts=LabelOpts(position="right"))
# 反转x轴和y轴
bar.reversal_axis()
# 设置每一年的图表的标题
bar.set_global_opts(
title_opts=TitleOpts(title=f"{year}年全球前8GDP数据")
)
timeline.add(bar, str(year))
# for循环每一年的数据,基于每一年的数,创建每一年的bar对象
# 在for中,将每一年的bar对象添加到时问线中
# 设置时间线自动播放
timeline.add_schema(
play_interval=1000,
is_timeline_show=True,
is_auto_play=True,
is_loop_play=False
)
# 绘图
timeline.render("1960-2019全球GDP前8国家.html")