Python—面向对象小解(4)

2024-06-01 04:44
文章标签 python 面向对象 小解

本文主要是介绍Python—面向对象小解(4),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、模块

1.1 Python自带模块

1.1.1 Json模块

处理json数据

'{"key":"value"}'

json不是字典 本质是一个有引号的字符串数据

json注意点 {} 中的数据是字符串引号必须是双引号

使用json模块可以实现将json转为字典,使用字典的方法操作数据 。 或者将字典转为json

json数据可以实现不同程序之间传递数据

比如使用json将python程序的数据传递java程

# json模块使用
# 导入模块
import json  # 直接导入模块# 1-打开读取jiso文件
with open('D:/Python大数据就业/4-Python基础/day07-模块-网络-多任务/4-资料/order_detial.json','r',encoding='utf-8') as f:data_lines  = f.readlines()print(data_lines)
# 2- 对读取的文件数据进行处理
# 需要将每行的json数据转为字典处理
for line in data_lines:# 对每行数据去除\nline_str = line.replace('\n','')print(line_str)# 将json字符串转为字典   loads     将字典数据转为json字符串 json_str = json.dumps(字典数据)# 如果直接导入模块 需要使用  模块名.函数()  模块名.变量line_dict = json.loads(line_str)print(type(line_dict))# 使用字典操作方法处理数据total_price= line_dict['total_price']print(total_price)

1.1.2 Datatime模块

# 日期时间模块
from datetime import datetime,timedelta# 获取当前日期时间
dt_now = datetime.now()
print(dt_now)
# 获取时间戳 timestamp需要将日期传递到方法中
unixtime_now = datetime.timestamp(dt_now)
print(unixtime_now)# 将时间戳数据转为datetime时间
dt = datetime.fromtimestamp(1617021920)
print(dt)# 日期的加减
# 获取加减的时间单位
t = timedelta(days=7)
dt_add = dt_now + t
print(dt_add)
dt_sub = dt_now - t
print(dt_sub)# 字符串时间 转为datetime类型的时间
dt_str = '2017-10-20 15:20:22'
dt2 = datetime.strptime(dt_str,'%Y-%m-%d %H:%M:%S')
print(type(dt2))# 将datetime类型数据转为 字符串
dt_now_str = dt_now.strftime('%Y/%m/%d %H:%M:%S')
print(dt_now_str)

1.1.3 Decimal模块

处理小数数据

类型是双精度浮点 保证小数计算时精度的准确性,一般在进行价格金额计算时使

# Decimal模块使用
# 导入模块中的所有函数,类,变量
from decimal import *
# 将小数数据转为Decimal
d = Decimal(3.1415926)
print(d)# 指定保留小数  会进行四舍五入
d2 = d.quantize(Decimal('0.000'))
print(d2)d3 = Decimal(5.123).quantize(Decimal('0.000'))d4 = d2+d3
print(d4)

1.1.4 random模块

随机产生数据

# random使用
# 将randint函数通过as命名了一个别称
# randint 可以根据指定范围随机产生一个整数数据
from random import randint as rtnum = rt(0,3)
print(num)name = ['张三','李四','王五','赵六','aa','bb']
# 随机产生下标
index = rt(0,len(name)-1)
print(name[index])# 验证码
date_str = '123456789asdfghjklqwertyuiopzxcvbnm'
index1 = rt(0,len(date_str)-1)
index2 = rt(0,len(date_str)-1)
index3 = rt(0,len(date_str)-1)
index4 = rt(0,len(date_str)-1)
code =  date_str[index1] + date_str[index2] + date_str[index3] +date_str[index4]
print(code)

1.2 三方模块

第三方开发的代码文件,上传到python的官方模块库中,方便其他开发人员使用

把代码开源个其他程序员

使用三方模块需要进行下载

pip下载安装

pip是python自带的包模块管理工具:

  1. 清华大学源:Simple Index

  2. 阿里云源:Simple Index

  3. 中国科技大学源:Simple Index

  4. 豆瓣源:http://pypi.douban.com/simple/

pip install 模块名==版本  -i 安装源

安装爬虫模块:

pip install requests -i https://pypi.tuna.tsinghua.edu.cn/simple

查看是否安装成功:

pip list

1.3 requests模块使用

可以数据采集,测试开发

网络通讯介绍

网络通讯就是程序之间进行通讯,相互传递数据内容

网络通讯三要素:

(1)IP地址:网络虚拟环境下的唯一标识,类似于人的身份证号,通过IP可以找到计算机;

(2)端口:表示计算机中某软件的地址信息,通过端口可以找到计算机中的软件;

(3)协议:协议就是通信规则,程序之间必须按照规则传递信息,否则双方无法识别彼此信

网络通讯模型

C/S模型

C:client

S:server

B/S模型

B:brower

S:server

TCP协议

规定了程序之间的通讯方式

TCP是双向通讯,类似手机通话 双方可以进行数据传递操作

UDP是单向通讯,类似广播 只能有一个人传递数据,其他人等待接收数据

安全数据传输方式是TCP

1-先连接对方程序,连接成功后会返回确认信息。 确认网络是否通畅

2-向对方程序发送数据,对方接受数后,会返回确认信息

3-数据发送完成,会在发送一个关闭连接的消息,对方接受到消息后就知道发送完成

HTTP协议

规定了程序之间的通讯数据格式

web开发中使用浏览器作为客户端,在进行数据传递时,使用http协议,规定了数据的格式

请求的数据格式 也叫作请求报文

  • 请求行 GET / HTTP/1.1

    • GET 请求方式 表示获取数据

    • POST 请求方式 上传数据

  • 请求头

    • User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36 代表设备信息

    • 头部中没有user-agent会认为是一个爬虫程序

  • 请求体

    • 携带请求数据

响应的数据格式 叫作响应报文 返回的结果不符合格式,就无法被浏览器解析获取

  • 响应行 HTTP/1.1 200 ok

    • HTTP/1.1 http协议斑斑

    • 200 响应状态 成功 400表示失败 404 找不到页面资源

    • ok 响应的信息

  • 响应头部

    • Content-Type: text/html; charset=utf-8 指定返回的数据形式 html前端页面

    • Server:BWS/1.1 服务名称

  • 响应体

    • 返回处理后的数据给浏览器

    • json

    • html页面

    • 图片

    • 视频

    • 音频

requests使用

数据采集的本质就是使用程序模拟浏览器的行为

Requests: HTTP for Humans™ — Requests 2.32.3 documentation

采集网址

返回json数据:

天气接口网址:https://api.oioweb.cn/api/weather/weather?city_name=北京市

返回网页html数据:

网页网址::

  • 获取json数据

# 请求服务器获取json数据
import requests# 1-发送请求
# 定义请求网址
url = 'https://api.oioweb.cn/api/weather/weather?city_name=上海市'
# 定义请求头部数据
headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36'
}
# 发送get请求
respose = requests.get(url,headers=headers) # 定义变量接收响应的数据# 对返回的json数据进行解析,转为字典
response_dict = respose.json()
print(response_dict)# 提取需要的字段数据
# 获取风向数据
wind_direction = response_dict['result']['wind_direction']
print(wind_direction)

  • 获取html页面数据

xpath语法 XPath 教程

html是标签语言,使用xpath可以提取标签中的数据

额外需要模块

lxml模块 将页面数据转为标签元素数据element,就可以使用xpath语法

安装lxml模块:

pip install lxml -i https://pypi.tuna.tsinghua.edu.cn/simple
# 获取html页面中数据
import requests
from lxml import etree# 1-发送请求
# 定义请求网址
url = '网站地址'
# 定义请求头部数据
headers = {
'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36'
}
# 发送get请求
respose = requests.get(url,headers=headers) # 定义变量接收响应的数据# 获取html的页面数据
html_text = respose.text# 将html页面转为element元素数据
html_element = etree.HTML(html_text)# 使用xpath语法开发获取数据
book_name1 = html_element.xpath('//*[@id="content-container"]/div[2]/div[3]/div/div[1]/div[1]/div[2]/p/a/text()')[0]
print(book_name1)

1.4 pymysql模块使用

PyMySQL documentation — PyMySQL 0.7.2 documentation

操作mysql数据

# 使用pymysql模块操作数据
import pymysql# 创建mysql的连接
clinet = pymysql.connect(host='localhost',port=3306,user='root',password='root')# 生成游标操作数据库
cur = clinet.cursor()# 数据库操作
# 本质是写sql语句,写在字符串中
sql_str = '''create database if not exists pydata45 charset=utf8
'''
# 执行sql
cur.execute(sql_str)# 创建表
sql_str2 = '''create table if not exists pydata45.user(id int,name varchar(20),age int,gender varchar(20))
'''
# 执行sql语句
cur.execute(sql_str2)# 写入数据
# 将列表数据写表中
sql_str3 = '''insert into pydata45.user values(%s,%s,%s,%s)
'''
data_list= [1,'张三',20,'男']
# 执行写入语句
cur.execute(sql_str3,data_list)
# 写入数据必须有commit
clinet.commit()# 将字典数据写入进入
sql_str4 = '''insert into pydata45.user values(%(id)s,%(username)s,%(age)s,%(gender)s)
'''
data_dict= {'id':2,'username':'李四','age':20,'gender':'男'}
# 执行写入语句
cur.execute(sql_str4,data_dict)
# 写入数据必须有commit
clinet.commit()# 查询写入的数据
sql_str5 = '''select * from pydata45.user
'''
# 执行sql语句
cur.execute(sql_str5)
# 获取查询的数据
data = cur.fetchall()
print(data)# 关闭连接
cur.close()
clinet.close()

1.4自定义模块使用

本质就是编写一个python文件

文件名要符合python的命名规

  • 定义一个模块文件

# 自定义的模块文件
# 封装业务代码
name = '张三'def add_func(a,b):data = a+breturn dataclass Student:def __int__(self,name,age):self.name = nameself.age = agedef func(self):print(self.name)print(self.age)
  • 其他开发人员使用模块文件

# 开发人员自己的代码文件
from itcast import name,add_func,Studentprint(name)
res = add_func(10,20)
print(res)s = Student('张三',20)
s.func()

这篇关于Python—面向对象小解(4)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1020015

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核