Python高级

news2024/11/25 12:52:29

不定长参数

位置不定长参数,获取参数args会整合为一个元组

def info(*args):
    print('arg is', args)
    print('type(arg) is', type(args))

info(1, 2, 3, 4, 'a', 'b')

# 输出
# arg is (1, 2, 3, 4, 'a', 'b')
# type(arg) is <class 'tuple'>

关键字不定长参数,,获取参数kwargs会整合为一个字典

def info2(**kwargs):
    print('kwargs is', kwargs)
    print('type(kwargs) is', type(kwargs))
    for k, v in kwargs.items():
        print(k, v)
    print(kwargs['age'])


# 测试数据
info2(name='Bob', age=20, sex='1')
# 输出
# kwargs is {'name': 'Bob', 'age': 20, 'sex': '1'}
# type(kwargs) is <class 'dict'>
# name Bob
# age 20
# sex 1
# 20

函数作为参数

def func(compute):
    print(type(compute))  # <class 'function'>
    result = compute(1, 2)
    return result

def compute(x, y):
    return x + y

print(func(compute(1,2)))  # == func(3)
# 错误发生是因为您直接将compute(1, 2)的结果作为参数传递给func()函数,
# 而不是传递函数本身。当您调用compute(1, 2)时,它返回一个整数(x和y的和)
print(func(compute))

匿名函数

def定义的函数有名字,可以重复多次使用

但是lambda定义的函数只能使用一次

无法写多行

意会...

def func(compute):
    print(type(compute))  # <class 'function'>
    result = compute(1, 2)
    return result


# def compute(x, y):
#     return x + y

print(func(lambda x, y: x + y))  # 3
print(func(lambda *args: sum(args)))  # 3

异常

try:
    a = 1 / 0
    print(a)
except:  # 捕获所有异常
    print('出错了1')
else:  # 没有出错执行这里
    print('没有出错')
finally:
    print('不管有没有出错,都会执行这里')

try:
    a = 1 / 0
    print(a)
except NameError as e:
    print(e)
    print('出错了2')
except ZeroDivisionError as e:
    print(e)
    print('除数不能为0')
except Exception as e:  # 上面捕获到了,这里不再执行
    print(e)
    print('出错了e')

Python包

从物理上看,包就是一个文件夹,在该文件夹下包含了一个_init_.py文件,该文件夹可用于包含多个模块文件从逻辑上看,包的本质依然是模块

testpackage.__init__.py

print('testpackage package __init__')

testpackage.run.py

print('run')

def fun1():
    print('fun1')

testpackage.py执行查看顺序

import testpackage.run
testpackage.run.fun1()

# testpackage package __init__
# 这是run.py的print输出
# 这里是run.py的fun1函数

对象

构造

class Student:
    name = '默认'
    age = 999

    # self表示类对象本身,只有通过self才能访问到对象属性
    def __init__(self, namex, agex):
        print(f"初始化:{self.name}-{self.age} -> {namex}-{agex}")
        self.name = namex
        self.age = agex


stu1 = Student('小明', 18)  
# 初始化:默认-999 -> 小明-18

内置方法

👾

__new__():创建并返回一个实例,这是在 __init__() 之前调用的。

__init__():初始化新创建的对象。

__del__():当对象即将被垃圾回收时调用,常用于资源清理。

__getattr__()__setattr__()__delattr__():控制属性的获取、设置和删除。

__call__():使对象可调用,像函数一样使用。

__str__(self)

__str__() 是 Python 中的一个特殊方法或者说魔术方法,主要用于定义类实例作为字符串表示的形式。当你试图打印一个对象或者将一个对象转换为字符串时,Python 会调用这个方法。

print(str(stu1))  # == print(stu1)
改造了__str__, 小明-18

__lt__(self, other)

__lt__() 是 Python 中的一个特殊方法,也称为魔术方法,用于比较两个对象的大小关系,具体来说是实现小于 (<) 操作符的功能。当一个对象实例 a 调用 a < b 时,如果 a 类型定义 __lt__() 方法,则该方法会被自动调用。

    def __lt__(self, other):
        return True if self.age < other.age else False

print(stu1 < stu2)  # True
print(stu1 > stu2)  # False

当执行 num1 < num2 时,Python 会自动调用 num1.__lt__(num2) 方法,根据其中的逻辑判断。如果需要与其他类型进行比较,一般还需要考虑类型检查以避免错误。

__eq__(self, other)

判断等于

为什么类定义函数要传入self

在Python中,子类定义函数(实际上是方法,即绑定到类实例的方法)时,需要传入self参数作为第一个参数,这是因为:

  1. 标识实例方法self参数标志着这是一个类的方法,而不是一个独立的函数。在面向对象编程(OOP)中,类的方法通常需要操作或访问类实例的状态(即实例变量)。self代表调用该方法的类实例本身,它让方法有了上下文,能够在方法内部访问和修改实例的属性。
  2. 隐式传递实例:当你通过类的实例调用一个方法时,Python会自动将实例作为第一个参数传给方法,这个参数在方法内部被称作self。例如,当你创建一个类Person并调用其say_hello方法时,实际上是这样运作的:
class Person:
    def say_hello(self):
        print(f"Hello, my name is {self.name}.")

person = Person(name="Alice")
person.say_hello()  # 在内部,Python自动做了 person.say_hello(person)
  1. 一致性与可读性:在Python中,这是一种约定俗成的标准,有助于提高代码的可读性和一致性。所有类的方法都应该接受self作为第一个参数,以便开发者一看就知道这是一个类方法,并且能够方便地访问和操作实例的属性和方法。

总结起来,self参数的存在是为了让方法能够与类实例绑定在一起,并在方法内部访问和修改实例状态。虽然在技术层面上可以使用其他名称替代self,但由于这是Python编程社区广泛接受的约定,因此强烈建议始终使用self作为类方法的第一个参数。

封装

内部变量不让外面用

在Python中,尽管不像某些其他编程语言那样具有明确的private关键字,Python提供了约定俗成的方式来标记和实现私有成员变量(以及方法)。要声明一个私有变量,通常在变量名前加两个下划线(__)作为前缀,例如:

class Phone:
    __current_vlotage = None

    def __keep_single_core(self):
        print('单核')


xiaomi = Phone()
# xiaomi.__keep_single_core()
# AttributeError: 'Phone' object has no attribute '__keep_single_core'. Did you mean: '_Phone__keep_single_core'?
xiaomi._Phone__keep_single_core()  # 可以这么取,但不建议
# print(xiaomi.__current_vlotage)
print(xiaomi._Phone__current_vlotage)

这主要是为了防止子类无意间覆盖基类的内部实现细节,而不是为了完全禁止访问。 

继承

方式1:
调用父类成员
使用成员变量:父类名.成员变量
使用成员方法:父类名.成员方法(self)
方式2:
使用super()调用父类成员
使用成员变量:super().成员变量
使用成员方法:super().成员方法()

class Phone:
    IMEI = '123456789'
    producer = 'Apple'

    def call_by_4g(self):
        print('4G')

class Camera:
    cmos = 'IMX989'
    producer = 'SONY'
    def take_photo(self):
        print('take photo')

# 多继承子类
class iPhone5s(Phone, Camera):
    def call_by_4g(self):
        super().call_by_4g()
    def call_by_5g(self):
        print('5G')
    def take_photo(self):
        super().take_photo()


p = iPhone5s()

p.take_photo()
print(p.producer)  # 同名属性,先继承Phone的producer

多态

函数的形参是父类,其实可以传入子类

类型注解

🐮🐴,就是为了提示IDE这是什么类型数据,使其可以提示,就是一个标记,写错了不影响程序

ll: list[int] = [1,2,3,4,5,6]

def fun(x:int, y:int)->int:
    return x+y

# Union注解
from typing import Union
mylist: list[Union[str,int]] = [1,2,6,'cxk',7,'asshole',0]
mydict: dict[str,Union[str,int]]={"name":"cxk", "age":20}

操作数据库

MySQL :: Download MySQL Installer

基本框架

from pymysql import Connection

conn = Connection(host='localhost',
                  port=3306,
                  user='root',
                  password='123456',
                  autocommit=True
                  )

print(conn.get_server_info())  # 获取服务器信息8.0.36
cursor = conn.cursor()
conn.select_db('mysql')

# cursor.execute('create table test_pymysql(id int);')
cursor.execute('select * from user')
# 取得查询结果,是一个元组
results: tuple = cursor.fetchall()
for result in results:
    print(result)

conn.close()

闭包

如何避免某个变量被访问和随便修改

基础闭包,本质上就是返回内部的一个函数

def outer(logo):
    def inner(msg):
        print(f'<{logo}>{msg}</{logo}>')

    return inner

fn1 = outer('Apple')
fn1('se3')
fn1('15 Pro')
# <Apple>se3</Apple>
# <Apple>15 Pro</Apple>

fn2 = outer('Google')
fn2('Pixel X')
fn2('Pixel 5')
# <Google>Pixel X</Google>
# <Google>Pixel 5</Google>

 

def outer(num1):
    def inner(num2):
        # num1+=num2  # num1无法修改
                      # cannot access local variable 'num1' 
                      # where it is not associated with a value
        nonlocal num1  # 允许修改
        num1 += num2
        print(num1)
    return inner

fn = outer(10)
fn(5)

优点:
无需定义全局变量即可实现通过函数,持续的访问、修改某个值
闭包使用的变量的所用于在函数内,难以被错误的调用修改

缺点:
由于内部函数持续引用外部函数的值,所以会导致这一部分内存空间不被释放,一直占用内存

装饰器

装饰器其实也是一种闭包,其功能就是在不破坏目标函数原有的代码和功能的前提下,为目标函数增加新功能。

def outer(func):
    def inner(*args):
        print('sleep start')
        func(args[0])
        print('sleep end')
    return inner

fn = outer(sleep)
fn(3)

设计模式

单例模式

创建类的实例后,就可以得到一个完整的、独立的类对象。

它们的内存地址是不相同的,即t1和t2是完全独立的两个对象。

某些场景下,我们需要一个类无论获取多少次类对象,都仅仅提供一个具体的实例用以节省创建类对象的开销和内存开销(比如微信只能开一个?)

🐎的,没下文了?就这么实现的?java都没这样啊

工厂模式

class Person:
    pass

class Student(Person):
    pass
class Teacher(Person):
    pass
class Factory:
    def create_person(self, type):
        if type == 'student':
            return Student()
        elif type == 'teacher':
            return Teacher()
        else:
            return None

factory = Factory()
student = factory.create_person('student')
teacher = factory.create_person('teacher')
print(student)
print(teacher)

使用工厂类的get_person()方法去创建具体的类对象
优点:
大批量创建对象的时候有统一的入口,易于代码维护,当发生修改,仅修改工厂类的创建方法即可
符合现实世界的模式,即由工厂来制作产品(对象)(优雅)

没有线程万万不能

import threading
from time import sleep


# threading_obj = threading.Thread(group=None,
#                                  target=None,
#                                  args=None,  元组传参
#                                  kwargs=None,字典传参
#                                  name=None,
#                                  daemon=None)

def fun1():
    while True:
        print('|||||||||||||||||')
        sleep(1)


def fun2():
    while True:
        print('—————————————————')
        sleep(1)


def sing1(huabei):
    while True:
        print(huabei)
        sleep(1)


def sing2(sihai):
    while True:
        print(sihai)
        sleep(1)


if __name__ == '__main__':
    # th1 = threading.Thread(target=fun1)
    # th2 = threading.Thread(target=fun2)
    # th1.start()
    # th2.start()
    huabei = threading.Thread(target=sing1, args=('华北无浪漫',))
    sihai = threading.Thread(target=sing2, kwargs={'sihai': '死海扬起帆'})  # 🐮🐴这里的key设计一定要和形参一致?
    huabei.start()
    sihai.start()

网络编程

服务端

import socket

# 创建socket对象
socket_server = socket.socket()

# 绑定ip地址端口
socket_server.bind(('localhost', 8888))

# 监听端口
socket_server.listen(1)  # 接受链接数量

# 等待客户端链接
# result: tuple = socket_server.accept()
# conn = result[0]  # 客户端服务端链接对象
# address = result[1]  # 客户端地址信息
conn, address = socket_server.accept()  # 阻塞方法

# 接受客户端消息
print('client', address, ': ')
while True:
    print(conn.recv(1024).decode('utf-8'))

    # 回复
    msg = input('回复:')
    if msg == 'exit':
        break
    conn.send(msg.encode('utf-8'))


# 关闭链接
conn.close()
socket_server.close()

客户端

import socket

# 创建socket对象
socket_client = socket.socket()

socket_client.connect(('localhost', 8888))

while True:
    msg = input('发送:')
    if msg == 'exit':
        break
    socket_client.send(msg.encode('utf-8'))

    rec = socket_client.recv(1024)
    print('收到回复', rec.decode('utf-8'))

socket_client.close()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1580462.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JavaSE:图书管理系统

目录 一、前言 二、内容需求 三、类的设计 &#xff08;一&#xff09;图书类 1.Book 类 2.BookList 类 &#xff08;二&#xff09;操作类 1.添加图书AddOperation类 2.借阅图书BorrowOperation类 3.删除图书DelOperation类 4.显示图书ShowOperation类 5.退出系统Ex…

Python代码识别minist手写数字【附pdf】

一、概述 对于人类而言,要识别图片中的数字是一件很容易的事情,但是,如何让机器学会理解图片上的数字,这似乎并不容易。那么,能否找出一个函数(模型),通过输入相关的信息,最终得到期望的结果呢? 二、python代码实现中涉及的输入输出内容: 输入:mnist数据集每一个…

HarmonyOS 开发-手写绘制及保存图片

介绍 本示例使用drawing库的Pen和Path结合NodeContainer组件实现手写绘制功能&#xff0c;并通过image库的packToFile和packing接口将手写板的绘制内容保存为图片。 效果图预览 使用说明 在虚线区域手写绘制&#xff0c;点击撤销按钮撤销前一笔绘制&#xff0c;点击重置按钮…

动态路由-基于vue-admin-template

基于 vue-admin-template的动态路由 1. 拆分静态路由与动态路由 静态路由----所有人都可以访问—首页/登录/404 动态路由–有权限的人才可以访问—组织/角色/员工/权限 2. 根据用户权限添加动态路由 获取对应的权限标识(vuex中actions中把用户资料通过return 进行返回&…

代码随想录算法训练营DAY17|C++二叉树Part.4|110.平衡二叉树、257.二叉树的所有路径、404.左叶子之和

文章目录 110.平衡二叉树思路伪代码CPP代码 257.二叉树的所有路径思路伪代码实现CPP代码 404.左叶子之和思路伪代码CPP代码 110.平衡二叉树 力扣题目链接 文章讲解&#xff1a;110.平衡二叉树 视频讲解&#xff1a;后序遍历求高度&#xff0c;高度判断是否平衡 | LeetCode&…

CSS导读 (复合选择器)

&#xff08;大家好&#xff0c;今天我们将继续来学习CSS的相关知识&#xff0c;大家可以在评论区进行互动答疑哦~加油&#xff01;&#x1f495;&#xff09; 目录 二、CSS的复合选择器 2.1 什么是复合选择器 2.2 后代选择器(重要) 2.3 子选择器(重要) Questions 小提…

七年老测试整理的RF框架大全,一看就会,一学就懂

1.RF框架 全称robot framework,一个基于python开发的&#xff0c;自动化测试框架&#xff0c;这个框架可以做&#xff1a;web自动化&#xff0c;接口自动化&#xff0c;APP自动化。 github官网 1&#xff09;.安装python 检查python环境 python -V或 pip -V 2&#xff09;.…

【linux基础】bash脚本的学习:定义变量及引用变量、统计目标目录下所有文件行数、列数

假设目的&#xff1a;统计并输出指定文件夹下所有文件行数 单个文件可以用 wc -l &#xff1b;多个文件&#xff0c;可以用通配符 / 借助bash脚本 1.定义变量名&#xff0c;使用引号 a"bestqc.com.map" b"Anno.variant_function" c"enrichment/GOe…

UE4_导入内容_Alembic文件导入器

Alembic文件导入器 Alembic文件格式(.abc)是一个开放的计算机图形交换框架&#xff0c;它将复杂的动画化场景浓缩成一组非过程式的、与应用程序无关的烘焙几何结果。虚幻引擎4(UE4)允许你通过 Alembic导入器 导入你的Alembic文件&#xff0c;这让你可以在外部自由地创建复杂的…

android支付宝接入流程

接入前准备 接入APP支付能力前&#xff0c;开发者需要完成以下前置步骤。 本文档展示了如何从零开始&#xff0c;使用支付宝开放平台服务端 SDK 快速接入App支付产品&#xff0c;完成与支付宝对接的部分。 第一步&#xff1a;创建应用并获取APPID 要在您的应用中接入支付宝…

Hot100【十一】:编辑距离

// 定义dp[i][j]: 表示word1前i个字符转换到word2前j个字符最小操作数 // 初始化dp[m1][n1] class Solution {public int minDistance(String word1, String word2) {int m word1.length();int n word2.length();// 1. dp数组int[][] dp new int[m 1][n 1];// 2. dp数组初…

代码算法训练营day14 | 理论基础、递归遍历

day14&#xff1a; 理论基础二叉树的分类&#xff1a;二叉树的种类&#xff1a;满二叉树完全二叉树二叉搜索树平衡二叉搜索树 二叉树的存储方式&#xff1a;链式存储顺序存储 二叉树的遍历方式&#xff1a;深度优先和广度优先遍历实现方式 二叉树的定义&#xff1a; 递归遍历递…

【攻防世界】web2(逆向解密)

进入题目环境&#xff0c;查看页面信息&#xff1a; <?php $miwen"a1zLbgQsCESEIqRLwuQAyMwLyq2L5VwBxqGA3RQAyumZ0tmMvSGM2ZwB4tws";function encode($str){$_ostrrev($str);// echo $_o;for($_00;$_0<strlen($_o);$_0){$_csubstr($_o,$_0,1);$__ord($_c)1;…

磁盘管理与文件管理

文章目录 一、磁盘结构二、MBR与磁盘分区分区的优势与缺点分区的方式文件系统分区工具挂载与解挂载 一、磁盘结构 1.硬盘结构 硬盘分类&#xff1a; 1.机械硬盘&#xff1a;靠磁头转动找数据 慢 便宜 2.固态硬盘&#xff1a;靠芯片去找数据 快 贵 硬盘的数据结构&#xff1a;…

重温OKHTTP源码

本文基于OkHttp4.12.0源码分析 官方地址 概括 本篇主要是对okhttp开源库的一个详细解析&#xff0c;包含详细的请求流程分析、各大拦截器的解读等。 使用方法 同步请求&#xff1a;创建一个OKHttpClient对象&#xff0c;一个Request对象&#xff0c;然后利用它们创建一个Ca…

动态代理

动态代理 动态代理和静态代理角色一致。 代理类是动态生成的&#xff0c;不是我们直接写好的。 动态代理分为俩大类&#xff1a;基于接口的动态代理、基于类的动态代理 基于接口&#xff1a;JDK动态代理&#xff08;以下示例就是这个&#xff09; 基于类&#xff1a;cglib jav…

微机原理——绪论

本篇文章是我在观看网课时记录的笔记。如有错误欢迎批评指正。 微机原理————绪论 我们在使用计算机时&#xff0c;最重要最核心的就是计算机的CPU(中央处理器)&#xff0c;决定了计算机的计算速度&#xff0c;但是CPU无法直接读取外界的温度、湿度、压力之类的物理量&…

MSTP/RSTP的保护功能

目录 原理概述 实验目的 实验内容 实验拓扑 1.配置RSTP/MSTP 2.配置BPDU保护 3.配置根保护 4.配置环路保护 5.配置TC-BPDU保护 原理概述 在RSTP或MSTP交换网络中&#xff0c;为了防止恶意攻击或临时环路的产生&#xff0c;可配置保护功能来增强网络的健壮性和安全性。…

VSCode配置AI自动补全插件Tabnine

面向软件开发人员的 AI 助手 使用 AI 代码完成更快地编写代码 什么是Tabnine Tabnine 是一款 AI 代码助手&#xff0c;可让您成为更好的开发人员。Tabnine 将通过所有最流行的编码语言和 IDE 的实时代码完成、聊天和代码生成来提高您的开发速度。 无论您将其称为 IntelliSens…

【网络捉鬼记】微信可以部分网页可以,其它网页打不开提示无法找到NDS地址

蹭网蹭得好好的&#xff0c;为啥突然这样呢&#xff1f; 发现微信可以&#xff0c;百度搜索网页可以打开但图片出不来&#xff0c;再点一个新闻进去又是上图的样子。 问AI&#xff01;却发现连质谱清言也打不开&#xff01;用自己热点问&#xff1a; 至于win10怎么更换DNS&…