当前位置: 首页 > news >正文

[学习笔记]黑马程序员python教程

文章目录

  • 思维导图
    • Python基础知识图谱
    • 面向对象
    • SQL入门和实战
    • Python高阶技巧
  • 第一阶段
    • 第九章:Python异常、模块与包
      • 1.9.1异常的捕获
        • 1.9.1.1 为什么要捕获异常
        • 1.9.1.2 捕获常规的异常
        • 1.9.1.3 捕获指定的异常
        • 1.9.1.4 捕获多个异常
        • 1.9.1.5 捕获全部异常
        • 1.9.1.6 异常的else
        • 1.9.1.7 异常的finally
      • 1.9.2 异常的传递
      • 1.9.3 Python模块
        • 1.9.3.1 什么是模块
        • 1.9.3.2 模块的导入
        • 1.9.3.3 自定义模块
      • 1.9.4 Python包
        • 1.9.4.1 什么是Python包
        • 1.9.4.2 导入包
        • 1.9.4.3 安装第三方包
    • 第十章:数据可视化-折线图可视化
      • 1.10.1 json数据格式
      • 1.10.2 pyecharts模块
      • 1.10.3 数据处理
      • 1.10.4 创建折线图
    • 第十一章:数据可视化-地图可视化
      • 1.11.1 基础地图使用
      • 1.11.2 国内疫情地图
      • 1.11.3 省级疫情地图-河南省
    • 第十二章:数据可视化-动态柱状图
      • 1.12.1 基础柱状图
      • 1.12.2 基础时间线柱状图
      • 1.12.3 GDP动态柱状图绘制
        • 1.12.3.1 列表的sort方法
        • 1.12.3.2 数据处理
  • 第二阶段
    • 第一章:面向对象
      • 2.1.1 初识对象
      • 2.1.2 类的成员方法
      • 2.1.3 类和对象
      • 2.1.4 构造方法
      • 2.1.5 其他内置方法-魔术方法
        • 2.1.5.1 __str__字符串方法
        • 2.1.5.2 __lt__小于符号比较方法
        • 2.1.5.3 __le__小于等于比较符号方法
        • 2.1.5.4 __eq__比较运算符实现方法
      • 2.1.6 封装
        • 2.1.6.1 私有成员
      • 2.1.7 继承
        • 2.1.7.1 单继承
        • 2.1.7.2 多继承
        • 2.1.7.3 复写和使用父类成员
      • 2.1.8 类型注解
        • 2.1.8.1 变量的类型注解
        • 2.1.8.2 函数(方法)的类型注解
        • 2.1.8.3 Union类型
      • 2.1.9 多态
      • 2.1.10 综合案例
        • 2.1.10.1 要求和数据内容
        • 2.1.10.2 需求分析
        • 2.1.10.3 文件读取
        • 2.1.10.4 数据计算
        • 2.1.10.5 可视化开发
    • 第二章:SQL入门和实战
      • 2.2.1 数据库介绍
        • 2.2.1.1 数据库管理系统
        • 2.2.1.2 数据库和SQL的关系
      • 2.2.2 MySQL的安装
      • 2.2.3 MySQL的入门使用
      • 2.2.4 SQL基础与DDL
        • 2.2.4.1 SQL语法特征
        • 2.2.4.2 数据库定义语言-DDL
      • 2.2.5 SQL-DML
      • 2.2.6 SQL-DQL
      • 2.2.7 Python & MySQL
        • 2.2.7.1 安装pymysql
        • 2.2.7.2 创建到MySQL的数据库链接
        • 2.2.7.3 执行非查询性质的SQL语句
        • 2.2.7.4 执行查询性质的SQL语句
        • 2.2.7.5 数据插入
      • 2.2.8 综合案例
        • 2.2.8.1 创建表
        • 2.2.8.2 实现步骤
        • 2.2.8.3 作业
  • 第三阶段:PySpark案例实战
      • 3.1.1 Spark是什么
      • 3.1.2 PySpark
    • 3.2 Python高阶技巧
      • 3.2.1 闭包
      • 3.2.2 装饰器
      • 3.2.3 设计模式
        • 3.2.3.1 单例模式
        • 3.2.3.2 工厂模式
      • 3.2.4 多线程
        • 3.2.4.1 进程、线程
        • 3.2.4.2 并行执行
        • 3.2.4.3 多线程编程
      • 3.2.5 网络编程
        • 3.2.5.1 Socket
        • 3.2.5.2 客户端和服务端
        • 3.2.5.3 Socket服务端编程
        • 3.2.5.4 Socket客户端开发
      • 3.2.6 正则表达式
        • 3.2.6.1 正则的三个基础方法
        • 3.2.6.2 元字符匹配
      • 3.2.7 递归

思维导图

Python基础知识图谱

在这里插入图片描述

面向对象

在这里插入图片描述

SQL入门和实战

在这里插入图片描述

Python高阶技巧

在这里插入图片描述

第一阶段

第九章:Python异常、模块与包

1.9.1异常的捕获

1.9.1.1 为什么要捕获异常

在这里插入图片描述

1.9.1.2 捕获常规的异常

在这里插入图片描述

1.9.1.3 捕获指定的异常

在这里插入图片描述
e是接受异常信息的变量

1.9.1.4 捕获多个异常

在这里插入图片描述

1.9.1.5 捕获全部异常

try:代码
except Exception as e:处理异常

1.9.1.6 异常的else

在这里插入图片描述

1.9.1.7 异常的finally

在这里插入图片描述

1.9.2 异常的传递

在这里插入图片描述
在这里插入图片描述
如果异常是在某一层产生,但是没有被catch,那么会继续往上层抛出,此时这一层的后续代码就不会执行。直到异常在某一层被catch,这一层的后续代码能继续执行。

1.9.3 Python模块

1.9.3.1 什么是模块

1.9.3.2 模块的导入

在这里插入图片描述

一般不要用from 模块名 import *,因为这样相当于把模块里的全部代码都导入python程序内,可能会出现重名问题。

1.9.3.3 自定义模块

在这里插入图片描述

注意:当导入多个模块时,且模块内有同名功能。当调用这个同名功能时,调用的是后面导入的模块的功能。

  • __main__
    在这里插入图片描述
  • __all__变量
    在这里插入图片描述

指定导入不受__all__影响

1.9.4 Python包

1.9.4.1 什么是Python包

在这里插入图片描述

必须有__init__.py文件才是python包

1.9.4.2 导入包

  • 方式一:
import 包名.模块名
包名.模块名.功能
from 包名 import 模块名
模块名.功能
from 包名.模块名 import 功能
功能
  • 方式二:
    必须在__init__.py文件中添加__all__ = [],来控制from 包名 import *允许导入的模块列表

1.9.4.3 安装第三方包

在这里插入图片描述

  • 如何安装第三方包
pip install 包名
  • pip的网络优化
    pip默认连接国外的服务器下载包,可以通过命令在国内的镜像服务器下载包
pip install -i https://pypi.tuna.tsinghua.edu.cn/simple 包名

pycharm也可以在右下角“解释器设置”中添加新的python包,下载时可以添加option参数来通过国内镜像服务器下载包

第十章:数据可视化-折线图可视化

在这里插入图片描述

1.10.1 json数据格式

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

为了将含中文的python数据转化为json字符串,需要使用参数ensure_ascii为False,表明不使用ascii码进行转化,而把内容直接输出出去,为True,则中文会转化为Unicode的字符

json_str = json.dumps(data, ensure_ascii=False)

1.10.2 pyecharts模块

pyecharts官网:pyecharts.org
pyecharts画廊官网:gallery.pyecharts.org(类似美术的展览会)
在这里插入图片描述
在这里插入图片描述
全局配置:针对图像进行设置,如标题、图例、工具箱
系列配置:针对具体轴数据进行设置
在这里插入图片描述
在这里插入图片描述

1.10.3 数据处理

在这里插入图片描述
在这里插入图片描述

1.10.4 创建折线图

在这里插入图片描述

第十一章:数据可视化-地图可视化

在这里插入图片描述

1.11.1 基础地图使用

在这里插入图片描述
在这里插入图片描述

is_piecewise=True表示开始手动校准范围
pieces表示具体的范围是多少
可以通过ab173.com的前端rgb颜色对照表来查看某种颜色对应的16位的颜色代码

1.11.2 国内疫情地图

在这里插入图片描述

1.11.3 省级疫情地图-河南省

第十二章:数据可视化-动态柱状图

在这里插入图片描述

1.12.1 基础柱状图

在这里插入图片描述

  • 反转柱状图,同时将数值标签放在右边
bar.add_yaxis("GDP", [30, 20, 10], label_opts=LabelOpts(position="right"))
bar.reversal_axis()

1.12.2 基础时间线柱状图

在这里插入图片描述
在这里插入图片描述

  • 设置自动播放
timeline.add_schema(play_interval=1000,is_timeline_show=True,is_auto_play=True,is_loop_play=True
)
  • 时间线设置主题
    在这里插入图片描述
import pyecharts.globals import ThemeType
timeline = Timeline({"theme": ThemeType.LIGHT}
)

1.12.3 GDP动态柱状图绘制

在这里插入图片描述

1.12.3.1 列表的sort方法

在这里插入图片描述
在这里插入图片描述

1.12.3.2 数据处理

在这里插入图片描述

python3.6后,字典是有序的,参考:https://juejin.cn/post/7041433783362387982
在这里插入图片描述
在这里插入图片描述
由于bar.reversal_axis()会将从左到右从大到小变成从上到下,从小到大,所以在绘制柱状图之前需要将x_data和y_data都反转一下

from pyecharts.charts import Bar, Timeline
from pyecharts.options import LabelOpts, TitleOpts
from pyecharts.globals import ThemeTypewith open("D:\计算机\Python\黑马程序员python教程\资料\可视化案例数据\动态柱状图数据\\1960-2019全球GDP数据.csv", "r", encoding="GB18030") as f:data_lines = f.readlines()data_lines.pop(0)data_dict = {}
for line in data_lines:line_list = line.split(",")year = int(line_list[0])country = line_list[1]gdp = float(line_list[2])try:data_dict[year].append([country, gdp])except KeyError:data_dict[year] = [[country, gdp]]timeline = Timeline({"theme": ThemeType.LIGHT}
)for year in data_dict:data_dict[year].sort(key = lambda x: x[1], reverse=True)year_data = data_dict[year][:8]x_data = []y_data = []for country_gdp in year_data:x_data.append(country_gdp[0])y_data.append(country_gdp[1] / 1E8)bar = Bar()x_data.reverse()y_data.reverse()bar.add_xaxis(x_data)bar.add_yaxis("GDP(亿)", y_data, label_opts=LabelOpts(position="right"))bar.reversal_axis()bar.set_global_opts(title_opts=TitleOpts(title=f"{year}年全球前8GDP数据"))timeline.add(bar, str(year))timeline.add_schema(play_interval=1000,is_timeline_show=True,is_auto_play=True,is_loop_play=True
)timeline.render("1960-2019全球GDP前8国家.html")

第二阶段

第一章:面向对象

2.1.1 初识对象

在这里插入图片描述

2.1.2 类的成员方法

在这里插入图片描述

定义在类内部的函数称之为类的方法
在这里插入图片描述
self相当于以后会创建但在定义类时还不存在的对象

2.1.3 类和对象

在这里插入图片描述

面向对象编程:设计类,基于类创建对象,由对象做具体的工作

2.1.4 构造方法

在这里插入图片描述

2.1.5 其他内置方法-魔术方法

在这里插入图片描述

2.1.5.1 __str__字符串方法

在这里插入图片描述

2.1.5.2 __lt__小于符号比较方法

在这里插入图片描述

2.1.5.3 __le__小于等于比较符号方法

在这里插入图片描述

2.1.5.4 __eq__比较运算符实现方法

在这里插入图片描述

2.1.6 封装

面向对象包含3大特性:封装、继承、多态
在这里插入图片描述

2.1.6.1 私有成员

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.1.7 继承

2.1.7.1 单继承

在这里插入图片描述

继承表示:将从父类那里继承(复制)成员变量和成员方法(不含私有)

2.1.7.2 多继承

在这里插入图片描述
在这里插入图片描述

pass关键字是用来补全语法的

2.1.7.3 复写和使用父类成员

在这里插入图片描述
在这里插入图片描述

2.1.8 类型注解

2.1.8.1 变量的类型注解

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.1.8.2 函数(方法)的类型注解

  • 函数(方法)的形参的类型注解
    在这里插入图片描述
  • 函数(方法)的返回值的类型注解
    在这里插入图片描述

2.1.8.3 Union类型

在这里插入图片描述
在这里插入图片描述

2.1.9 多态

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.1.10 综合案例

2.1.10.1 要求和数据内容

在这里插入图片描述
在这里插入图片描述

2.1.10.2 需求分析

在这里插入图片描述

2.1.10.3 文件读取

  • data_define.py
"""
数据定义的类
"""class Record:def __init__(self, date, order_id, money, province):self.date = date            # 订单日期self.order_id = order_id    # 订单IDself.money = money          # 订单金额self.province = province    # 销售省份def __str__(self):return f"{self.date}, {self.order_id}, {self.money}, {self.province}"
  • file_define.py
"""
和文件相关的类定义
"""
import json
from data_define import Record# 先定义一个抽象类用来做顶层设计,确定有哪些功能需要实现
class FileReader:def read_data(self) -> list[Record]:"""读取文件的数据,读到的每一条数据都转换为Record对象,将它们都封装到list内返回即可"""passclass TextFileReader(FileReader):def __init__(self, path):self.path = path              # 定义成员变量记录文件的路径# 复写(实现抽象方法)父类的方法def read_data(self) -> list[Record]:with open(self.path, 'r', encoding='utf-8') as f:record_list: list[Record] = []for line in f.readlines():line = line.strip()    # 消除读取到的每一行数据中的\ndata_list = line.split(",")record = Record(data_list[0], data_list[1], int(data_list[2]), data_list[3])record_list.append(record)return record_listclass JsonFileReader(FileReader):def __init__(self, path):self.path = path              # 定义成员变量记录文件的路径def read_data(self) -> list[Record]:with open(self.path, 'r', encoding='utf-8') as f:record_list: list[Record] = []for line in f.readlines():data_dict = json.loads(line)record = Record(data_dict['date'], data_dict['order_id'], int(data_dict['money']), data_dict['province'])record_list.append(record)return record_listif __name__ == '__main__':text_file_reader = TextFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年1月销售数据.txt")json_file_reader = JsonFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年2月销售数据JSON.txt")list1 = text_file_reader.read_data()list2 = json_file_reader.read_data()for l in list1:print(l)for l in list2:print(l)

2.1.10.4 数据计算

  • main.py
from file_define import FileReader, TextFileReader, JsonFileReader
from data_define import Recordtext_file_reader = TextFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年1月销售数据.txt")
json_file_reader = JsonFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年2月销售数据JSON.txt")jan_data: list[Record] = text_file_reader.read_data()
feb_data: list[Record] = json_file_reader.read_data()
# 将2个月份的数据合并为1个list来存储
all_data: list[Record] = jan_data + feb_data# 开始进行数据计算
data_dict = {}
for record in all_data:if record.date in data_dict:data_dict[record.date] += record.moneyelse:data_dict[record.date] = record.money

2.1.10.5 可视化开发

# 可视化图表开发
bar = Bar(init_opts=InitOpts(ThemeType.LIGHT))
bar.add_xaxis(list(data_dict.keys())) # 添加x轴数据
bar.add_yaxis("销售额", list(data_dict.values()), label_opts=LabelOpts(is_show=False))
bar.set_global_opts(title_opts=TitleOpts(title="每日销售额")
)bar.render("每日销售额柱状图.html")

第二章:SQL入门和实战

在这里插入图片描述

2.2.1 数据库介绍

在这里插入图片描述

2.2.1.1 数据库管理系统

在这里插入图片描述

2.2.1.2 数据库和SQL的关系

在这里插入图片描述

2.2.2 MySQL的安装

mysql的官网:www.mysql.com
略,详细请参考视频

2.2.3 MySQL的入门使用

在这里插入图片描述

2.2.4 SQL基础与DDL

在这里插入图片描述
在这里插入图片描述

2.2.4.1 SQL语法特征

在这里插入图片描述

2.2.4.2 数据库定义语言-DDL

  • DDL-库管理
# 查看数据库
SHOW DATABASES;
# 使用数据库
USE 数据库名称;
# 创建数据库
CREATE DATABASE 数据库名称 [CHARSET UTF8];
# 删除数据库
DROP DATABASE 数据库名称;
# 查看当前使用的数据库
SELECT DATABASE();
  • DDL-表管理
# 查看有哪些表
show tables;
# 删除表
drop table 表名称;
drop table if exists 表名称;
# 创建表
create table 表名称(列名称 列类型,列名称 列类型,......
);
-- 列类型有
int	 			-- 整数
float 			-- 浮点数
varchar(长度) 	-- 文本,长度为数字,做最大长度限制
date			-- 日期类型
timestamp		-- 时间戳类型

2.2.5 SQL-DML

DML-数据操作语言。

  • 插入
    在这里插入图片描述
  • 删除
    在这里插入图片描述
  • 更新
    在这里插入图片描述

2.2.6 SQL-DQL

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.2.7 Python & MySQL

2.2.7.1 安装pymysql

在这里插入图片描述

2.2.7.2 创建到MySQL的数据库链接

在这里插入图片描述

2.2.7.3 执行非查询性质的SQL语句

cursor = conn.cursor()
conn.select_db("test")
cursor.execute("create table test_pymysql2(id int)")

2.2.7.4 执行查询性质的SQL语句

cursor = conn.cursor()
conn.select_db("world")
cursor.execute("select * from student")
results = cursor.fetchall()
for r in results:print(r)

2.2.7.5 数据插入

  • commit提交 在这里插入图片描述
  • 自动conmmit 在这里插入图片描述

2.2.8 综合案例

2.2.8.1 创建表

在这里插入图片描述

2.2.8.2 实现步骤

在这里插入图片描述

from file_define import FileReader, TextFileReader, JsonFileReader
from data_define import Record
from pymysql import Connectiontext_file_reader = TextFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年1月销售数据.txt")
json_file_reader = JsonFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年2月销售数据JSON.txt")jan_data: list[Record] = text_file_reader.read_data()
feb_data: list[Record] = json_file_reader.read_data()
# 将2个月份的数据合并为1个list来存储
all_data: list[Record] = jan_data + feb_dataconn = Connection(host="127.0.0.1",port=3306,user="root",password="xxxxxx",autocommit=True
)cursor = conn.cursor()
conn.select_db("py_sql")
for record in all_data:sql = f"INSERT INTO orders(`order_date`, `order_id`, `money`, `province`) " \f"VALUES ('{record.date}', '{record.order_id}', {record.money}, '{record.province}')"cursor.execute(sql)conn.close()

2.2.8.3 作业

在这里插入图片描述

import json
from file_define import FileReader, TextFileReader, JsonFileReader
from data_define import Record
from pymysql import Connectiontext_file_reader = TextFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年1月销售数据.txt")
json_file_reader = JsonFileReader("D:\\计算机\\Python\\黑马程序员python教程\\资料\\数据分析案例\\2011年2月销售数据JSON.txt")jan_data: list[Record] = text_file_reader.read_data()
feb_data: list[Record] = json_file_reader.read_data()
# 将2个月份的数据合并为1个list来存储
all_data: list[Record] = jan_data + feb_dataconn = Connection(host="127.0.0.1",port=3306,user="root",password="xxxxxx",autocommit=True
)cursor = conn.cursor()
conn.select_db("py_sql")
sql = f"select * from orders"
cursor.execute(sql)with open("./json.txt", 'a', encoding='utf-8') as f:for line in cursor.fetchall():dict = {}dict['date'] = str(line[0])dict['order_id'] = line[1]dict['money'] = line[2]dict['province'] = line[3]tmp = json.dumps(dict, ensure_ascii=False)f.write(tmp + '\n')conn.close()

第三阶段:PySpark案例实战

3.1.1 Spark是什么

Apache Spark是用于大规模数据处理的统一分析引擎。简单来说,Spark是一款分布式计算框架,可以调度成百上千的服务器集群。

3.1.2 PySpark

在这里插入图片描述
在这里插入图片描述
因为已经学过PySpark了,这里略。

3.2 Python高阶技巧

3.2.1 闭包

  • 闭包(函数)
    在这里插入图片描述

  • 在闭包(函数)内修改外部函数的值-nonlocal关键字
    在这里插入图片描述

  • 优缺点 在这里插入图片描述

3.2.2 装饰器

在这里插入图片描述

装饰器核心思想是:将需要被包装的函数作为参数传递
在这里插入图片描述
语法糖:也叫糖衣语法,对语言的功能并没有影响,而是更方便程序员使用

3.2.3 设计模式

在这里插入图片描述

3.2.3.1 单例模式

在这里插入图片描述
在这里插入图片描述

3.2.3.2 工厂模式

在这里插入图片描述
在这里插入图片描述

3.2.4 多线程

3.2.4.1 进程、线程

在这里插入图片描述

进程是系统资源调度的基本单位,线程是系统资源的最小单位

在这里插入图片描述

3.2.4.2 并行执行

在这里插入图片描述

3.2.4.3 多线程编程

  • threading模块
    在这里插入图片描述

每个Thread类对象就是多线程中的一个线程
把工作封装到函数里,然后传入到target参数

  • 具体需求
    在这里插入图片描述
  • 代码实现
  • 在这里插入图片描述
  • 传参
    在这里插入图片描述
    在这里插入图片描述

3.2.5 网络编程

3.2.5.1 Socket

在这里插入图片描述

3.2.5.2 客户端和服务端

在这里插入图片描述

3.2.5.3 Socket服务端编程

在这里插入图片描述
在这里插入图片描述

  • 实现服务端并结合客户端进行测试
    在这里插入图片描述
import socket# 创建Socket对象
socket_server = socket.socket()
# 绑定ip地址和端口
socket_server.bind(('localhost', 8888))
# 监听端口
socket_server.listen(1)
# listen方法内接受一个整数传参数,表示接受链接数量
# 等待客户端链接
conn, address = socket_server.accept()
# accpet方法返回的是二元元组(链接对象, 客户端地址信息)
# accpet方法是阻塞方法,等待客户端链接,如果没有链接,就卡在这一行不向下执行
print(f"接收到了客户端的链接,客户端的信息是:{address}")
# 接受客户端信息
data = conn.recv(1024).decode('utf8')
# recv也是阻塞方法,等待客户端发送信息
# recv接受的参数是缓冲区大小,一般给1024即可
# recv方法的返回值是一个字节数组(bytes对象),不是字符串,可以通过decode方法通过utf0编码,将字节数组转换为字符串对象
print(f"客户端发来的消息是:{data}")
# 发送恢复消息
msg = input("请输入你要和客户端回复的消息:")
conn.send(msg.encode('utf8'))
# encode可以将字符串编码为字节数组对象
conn.close()
socket_server.close()

3.2.5.4 Socket客户端开发

在这里插入图片描述
在这里插入图片描述

3.2.6 正则表达式

在这里插入图片描述

3.2.6.1 正则的三个基础方法

  • re.match

在这里插入图片描述

  • re.search
    在这里插入图片描述
  • re.findall
    在这里插入图片描述

3.2.6.2 元字符匹配

  • 单字符匹配
    在这里插入图片描述

字符串前面带上r的标记,表示字符串中转义字符无效,就是普通字符的意思

  • 数量匹配
    在这里插入图片描述
  • 边界匹配
    在这里插入图片描述
  • 分组匹配
    在这里插入图片描述
  • 案例
    在这里插入图片描述

{}中间别带空格

3.2.7 递归

在这里插入图片描述
在这里插入图片描述

相关文章:

[学习笔记]黑马程序员python教程

文章目录思维导图Python基础知识图谱面向对象SQL入门和实战Python高阶技巧第一阶段第九章:Python异常、模块与包1.9.1异常的捕获1.9.1.1 为什么要捕获异常1.9.1.2 捕获常规的异常1.9.1.3 捕获指定的异常1.9.1.4 捕获多个异常1.9.1.5 捕获全部异常1.9.1.6 异常的else…...

如何配置用于构建 FastReport Online Designer 的 API ?

FastReport Online Designer 是一个跨平台的报表设计器,允许通过任何平台的移动设备创建和编辑报表。今天我们就一起来看看在2023版中新增和改进的功能有哪些,点击下方可以获取最新版免费试用哦! FastReport Onlin Designe最新版试用https:/…...

【嵌入式Linux内核驱动】02_字符设备驱动

字符设备驱动 〇、基本知识 设备驱动分类 (按共性分类方便管理) 1.字符设备驱动 字符设备指那些必须按字节流传输,以串行顺序依次进行访问的设备。它们是我们日常最常见的驱动了,像鼠标、键盘、打印机、触摸屏,还有…...

【零散整理】

1-1 git查看代码的项目总行数 git log --prettytformat: --numstat | awk ‘{ add $1; subs $2; loc $1 - $2 } END { printf “added lines: %s, removed lines: %s, total lines: %s\n”, add, subs, loc }’ - 1-2 cookie const cookies document.cookie.split(; )for…...

RocketMQ重复消费的症状以及解决方案

RocketMQ重复消费的症状以及解决方案 生产消息时重复 症状 当一条消息已被成功发送到 消费者 并完成持久化,此时出现了网络闪断或者客户端宕机,导致服务端对客户端应答失败。 如果此时 生产者 意识到消息发送失败并尝试再次发送消息,消费者…...

数字化时代,企业的商业模式建设

随着新一代信息化、数字化技术的应用,众多领域通过科技革命和产业革命实现了深度化的数字改造,进入到以数据为核心驱动力的,全新的数据处理时代,并通过业务系统、商业智能BI等数字化技术和应用实现了数据价值,从数字经…...

项目实战典型案例23——-注册上nacos上的部分服务总是出现频繁掉线的情况

注册上nacos上的部分服务总是出现频繁掉线的情况一:背景介绍二:思路&方案解决问题过程涉及到的知识nacos服务注册和服务发现一:背景介绍 spring cloud项目通过nacos作为服务中心和配置中心,出现的问题是其中几个服务总是出现…...

玩转金山文档 3分钟让你的文档智能化

在上个月底,我们给大家推荐了金山轻维表的几个使用场景,社群中不少用户反响很好,对其中一些场景的解决方案十分感兴趣。但也有一些人表示,有些场景不知道如何实现,希望我们能提供模版/教程。这次我们将做一期热门模板盘…...

安装了nodejs怎么安装nvm

第一步,从控制面板卸载已经安装的node 第二步,删除C盘program开头文件夹下的node文件 第三步,去C/user/用户名 文件夹下,删除.npmrc文件 第四步,打开隐藏文件,第三步文件夹下有一个Appdata文件&#xff…...

java安全编码规范考试

java安全编码规范考试 整理不易,收点币!! 安全编码规范考试.md 下面对zip文件的安全解压缩描述,错误的是 A.zip文件解压时,可以使用entry.getSize()对解压缩文件进行文件大小判断 B.zip文件解压时&…...

表格检测识别技术的发展历程

近年来,随着计算机技术的飞速发展,越来越多的研究者开始关注表格检测识别技术。表格检测识别技术是一种利用计算机自动处理表格的技术,它可以实现从文本中检测出表格,并进行识别和提取。这种技术有助于提高文本处理的效率&#xf…...

设计UI - Adobe xd对象介绍

矩形工具 新建矩形 操作步骤:选择矩形工具,快捷键R,鼠标在画板上拖出矩形即可。 拖动定界框周围圆形手柄,可快速调整矩形大小,也可以输入宽和高的参数对矩形大小进行改变。 移动矩形 操作步骤:选择选择工具…...

优思学院|精益生产中的“单件流”真的能够做到吗?

精益生产中提到的“一个流”(One Piece Flow)是一种生产方式,它的核心理念是通过合理配置作业场地、人员和设备,使产品从投入到成品产出的整个制造加工过程中始终处于不停滞、不堆积、不超越,按节拍一个一个地流动。 …...

移除元素问题解决方法------LeetCode-OJ题

问题: 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。 要求: 不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改…...

JavaScript学习笔记(1.0)

push() 语法:数组.push(数据) 作用:将数据追加到数组的末尾 返回值:追加数据后数组最新的长度 pop() 语法:数组.pop() 作用:删除数组最后一个数据 返回值:被删除的数据 unshift() 语法:数…...

FCN网络介绍

目录前言一.FCN网络二.网络创新点前言 在图像分割领域,有很多经典的网络,如MASK R-CNN,U-Net,SegNet,DeepLab等网络都是以FCN为基础进行设计的。我们这里简单介绍一下这个网络。 一.FCN网络 FCN网络介绍   FCN 即全…...

Idea+maven+spring-cloud项目搭建系列--11 整合dubbo

前言: 微服务之间通信框架dubbo,使用netty (NIO 模型)完成RPC 接口调用; 1 dubbo 介绍: Apache Dubbo 是一款 RPC 服务开发框架,用于解决微服务架构下的服务治理与通信问题,官方提…...

2023年上半年北京杭州/广州深圳软考中/高级报名入口

软考是全国计算机技术与软件专业技术资格(水平)考试(简称软考)项目,是由国家人力资源和社会保障部、工业和信息化部共同组织的国家级考试,既属于国家职业资格考试,又是职称资格考试。 系统集成…...

jupyter notebook配置和使用

简介 Jupyter Notebook是基于网页的用于交互计算的应用程序。其可被应用于全过程计算:开发、文档编写、运行代码和展示结果。 参考博客:https://zhuanlan.zhihu.com/p/33105153 特点 ①编程时具有语法高亮、缩进、tab补全的功能。 ② 可直接通过浏览器…...

【C++】通过stack、queue、deque理解适配器模式

破镜不能重圆,枯木可以逢春。 文章目录一、stack1.stack的介绍2.stack相关OJ题(巧妙利用stack数据结构的特征)3.stack的模拟实现二、queue1.queue的介绍2.queue的相关OJ题(巧妙利用queue数据结构的特征)3.queue的模拟实…...

JavaScript 高级实例集合

文章目录JavaScript 高级实例集合创建一个欢迎 cookie简单的计时另一个简单的计时在一个无穷循环中的计时事件带有停止按钮的无穷循环中的计时事件使用计时事件制作的钟表创建对象的实例创建用于对象的模板JavaScript 高级实例集合 创建一个欢迎 cookie 源码 <!DOCTYPE ht…...

Flutter(五)容器类组件

布局类组件包含多个子组件&#xff0c;而容器类组件只包含一个子组件 目录填充&#xff08;Padding&#xff09;装饰容器&#xff08;DecoratedBox&#xff09;变换&#xff08;Transform&#xff09;Transform.translate 平移Transform.rotate 旋转Transform.scale 缩放Rotate…...

实现满屏品字布局

html, body {width: 100%;height: 100%;}.first {width: 50%;height: 50%;margin: auto;background-color: pink;}.second {width: 50%;height: 50%;float: left;background-color: greenyellow;}.third {width: 50%;height: 50%;float: left;background-color: yellow;}...

软件测试-性能测试-基础知识

文章目录 1.性能测试理论1.1 相关概念1.2 性能测试指标2.性能测试策略2.1 基准测试2.2 负载测试2.3 稳定性测试2.4 其他测试策略3.性能测试的流程3.1 需求分析3.2 编写性能测试计划和方案3.3 编写性能测试用例3.4 性能测试执行3.5 性能测试报告4.性能测试工具4.1 Loadrunner4.2…...

java多线程与线程池-02线程池与锁

线程池与锁 第4章 线程池入门 4.1 ThreadPoolExecutor ThreadPoolExecutor是应用最广的底层线程池类,它实现了Executor和ExecutorService接口。 4.1.1 创建线程池 下面创建一个线程池,通过调整线程池构造函数的参数来了解线程池的运行特性。把核心线程数设置为3,最大…...

AB测试——流程介绍(设计实验)

前言&#xff1a; 作为AB测试的学习记录&#xff0c;接上文内容&#xff0c; 本文继续介绍假设建立和实验设计部分&#xff0c;包括实验对象、样本量计算&#xff08;显著性水平、统计功效及最小可检测效应&#xff09;、实验周期。 相关文章&#xff1a; AB测试——原理介绍 A…...

C++中的智能指针有哪些?分别解决的问题以及区别?

1.C中的智能指针有4种&#xff0c;分别为&#xff1a;shared_ptr、unique_ptr、weak_ptr、auto_ptr&#xff0c;其中auto_ptr被C11弃用。 2.使用智能指针的原因 申请的空间&#xff08;即new出来的空间&#xff09;&#xff0c;在使用结束时&#xff0c;需要delete掉&#xff0…...

通达信捉妖改良CCI指标公式,简洁巧妙

高端的食材&#xff0c;往往只需要简单的烹饪方式。好的指标也是一样&#xff0c;只需要简单处理&#xff0c;就可以实现不错的效果。捉妖改良CCI指标公式属于意外之喜&#xff0c;编写指标时写错了&#xff0c;研究后发现结果比原想法更好。 捉妖改良CCI指标公式利用了CCI&am…...

「Python 基础」面向对象编程

文章目录1. 面向对象编程类和实例访问限制继承和多态type()isinstance()dir()实例属性和类属性2. 面向对象高级编程\_\_slots\_\_property多重继承定制类枚举类元类1. 面向对象编程 Object Oriented Programming 简称 OOP&#xff0c;一种程序设计思想&#xff0c;以对象为程…...

【K3s】第23篇 一篇文章带你学习k3s私有镜像仓库配置

目录 1、私有镜像仓库配置 2、registries.yaml Mirrors Configs 1、私有镜像仓库配置 可以配置 Containerd 连接到私有镜像仓库,并使用它们在节点上拉取私有镜像。 启动时,K3s 会检查/etc/rancher/k3s/中是否存在registries.yaml文件,并指示 containerd 使...

柳州免费做网站的公司/百度推广

参考博客&#xff1a; 链接: Android软著申请总结...

网站空间管理权限/怎么联系百度客服

shp2sdo.exe用法&#xff1a;shpfile导入OracleSpatial 2011-07-14 13:11:22 http://pengjh.blog.51cto.com/2793198/610856 标签&#xff1a;shp2sdo shpfile oracle oraclespatial 休闲 原创作品&#xff0c;允许转载&#xff0c;转载时请务必以超链接形式标明文章 原始出处…...

国外常用视频网站tenor怎么设置/seo搜索引擎是什么

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 安全生产模拟考试一点通&#xff1a;2021年电工&#xff08;初级&#xff09;考试内容为正在备考电工&#xff08;初级&#xff09;操作证的学员准备的理论考试专题&#xff0c;每个月更新的电工&#xff08;初级&…...

开源项目网站怎么做 带视频/山东seo网页优化外包

游戏开发到后期&#xff0c;随之而来的是各种性能测试调优。前两天看两年前写的数据库服务器&#xff0c;那叫一个囧&#xff0c;当初设计是单线程的&#xff0c;也就是所有的数据库操作请求放入一个队列中&#xff0c;逐个取出来做数据库查询操作。虽然mysql 的性能很赞&#…...

自学做网站多久/个人怎么做互联网推广平台

相信不少开发者都会对 Windows Server 和 Linux 之间的网络性能差异感兴趣。Phoronix 网站近日测试了 Windows Server 2016 和 Linux 发行版上的一些 Netperf 网络性能指标。我们看看结果如何。测试机器配置为&#xff1a;AMD EPYC 7551 GIGABYTE MZ31-AR0 8 x 4GB DDR4-2666…...

遵义网站建设哪家好/国外网站排行

巧克力棒(chocolate)Time Limit:1000ms Memory Limit:64MB题目描述LYK 找到了一根巧克力棒&#xff0c;但是这根巧克力棒太长了&#xff0c; LYK 无法一口吞进去。具体地&#xff0c;这根巧克力棒长为 n&#xff0c;它想将这根巧克力棒折成 n 段长为 1 的巧克力棒&#xff0c;然…...