我的编程空间,编程开发者的网络收藏夹
学习永远不晚

元类, pymysql

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

元类, pymysql

元类, pymysql

一、元类

  • 自定义元类
'''
1、什么是元类?
    - 类的类就是type,其实type就是元类

2、元类的作用?

3、如何创建元类以及使用?
'''

# # 1、一切皆对象
# list1 = []  # list1 = list([])
# print(type(list1))  #

#
# # # 2、自定义一个类
# class Chinese(object):
#     country = 'china'
#
#     def __init__(self, name, age, sex):
#         self.name = name
#         self.age = age
#         self.sex = sex
#
#
# obj = Chinese('yafeng', 18, 'male')
# print(type(obj))   #
# print(Chinese)    #类本质上也是一个对象,Python中一且皆对象
# # ,


# 3、如何产生类
#1) 通过class关键字产生类
#2) 通过调用type类:type()  ----> obj ---->Chinese


# what:指的是类名
# bases:继承的父类(object)
# dict:类的名称空间

#
# code = '''
# country = 'china'
# def __init__(self, name, age, sex):
#     self.name = name
#     self.age = age
#     self.sex = sex
# '''

# class_attr = {}
# exec(code, {}, class_attr)
#
#
# # type(类的名字, 类的基类,类的名称空间)
# obj = type('Chinese', (object, ), class_attr)
# print(obj)  #
# print(Chinese)

#1、什么是元类?
# 类的类就是type,其实type就是元类


# 2、为什么要使用元类?
# 因为元类可以控制类的创建过程

#type是python内置的元类


# 自定义一个元类
class MyMetaClass(type):


    #控制类的创建
    # 优酷需要使用的部分
    def __init__(self, class_name, class_bases, class_dict):
        print(type(class_name))

        #要求类的首字母必须大写
        if not class_name.istitle():
            raise NameError('类的首字母必须大写!')

        # 规定类必须要写注释
        if not class_dict.get('__doc__'):
            raise TypeError('必须得写注释!!!')

        # 必须将类的类名,类的基类,类的名称空间一并返给 type 中的__init__
        super().__init__(class_name, class_bases, class_dict)



    # 了解:元类更深层次的作用
    # 控制调用类的行为
    # 为什么调用类就一定会产生一个空对象,为什么一定会执行__new__
    # 其实就是type 内部一定会调用一次__call__,有__call__来帮你调用__new__

    # 元类中的__call__就是创建类的过程!!!
    def __call__(self, *args, **kwargs):
        print(args)   # User类括号中的值
        # 1、造一个空对象obj
        obj = object.__new__(self) # 创造一个空对象 self ---> User

        print(obj.__dict__, 1111111)

        # 2、调用类时,__call__会立马调用User.__init__, 并且将obj连同User括号内的参数一同传给__init__
        self.__init__(obj, *args, **kwargs)

        # return 一个真正创建的对象
        return obj


## obj = MyMetaClass()
# obj()   # obj()---->  User(10,20) ---->user_obj


# 被控制类在定义阶段 类名(metaclass=自定义的元类)---->会将当前类的类名、基类、类的名称空间  一并传给 自定义的元类

# metaclass --->自定义的元类看---->低调做那个自定义的元类(类名,基类,类的名称空间)

# type(类名,基类,类的名称空间)

class User(object, metaclass=MyMetaClass):  # MyMetaClass(User, (object,), {'x':10})

    '''我要成为年薪百万的男人,tank老师很好啊,向他学习'''

    def __init__(self):
        pass

    x = 10
    pass


obj = User()

print(obj)

二、pymysql

  • 通过pymysql 去连接数据库
# 下载第三方模块:在cmd 中下载

# pip install pymysql



# 面条版
import pymysql

# 1.连接数据库
client = pymysql.connect(
    host='127.0.0.1',
    port=3306,
    user='root',
    password='123456',
    database='db4',
    charset='utf8',  #此处不能写utf-8
    autocommit=True
)

# print(client)


# 2.获取游标对象 ---->游标 可以用来提交sql命令
course_obj = client.cursor(pymysql.cursors.DictCursor)


# 3.通过execute 可以提交sql语句

# 1) 查数据
# sql = 'select * from emp'
#
# # 提交sql语句
# course_obj.execute(sql)
#
# #4.提交后,通过cursor_obj 对象.fetchall()  获取所有查询到的结果
#
# res = course_obj.fetchall()
# print(res)
#
# for dic in res:
#     print(dic)

# 2) 插入数据
# 创建表
# sql = 'create table user(id int, name varchar(16))'
# course_obj.execute(sql)
#
# sql = 'insert into user(id, name) values(1, "yafeng")'
# course_obj.execute(sql)


# 注意得运行后才可以上传到数据库


# 3) 更新数据
# try:
#     sql = 'update user set name="yafeng_很帅" where id=1'
#
#     course_obj.execute(sql)
#
# except Exception as e:
#     print(e)

# # 4) 删除数据
# sql = 'delete from user'
# course_obj.execute(sql)

# 关闭游标
# course_obj.close()
#
#
# # 关闭客户端连接
# client.close()

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

元类, pymysql

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

元类, pymysql

元类, pymysql一、元类自定义元类'''1、什么是元类? - 类的类就是type,其实type就是元类2、元类的作用?3、如何创建元类以及使用?'''# # 1、一切皆对象# list1 = [] # list1 = list([])# prin
2020-12-26

pymysql

python代码连接mysql数据库有bug(sql注入的问题):#pip3 install pymysqlimport pymysqluser=input("user>>: ").strip()pwd=input("password>>: ").strip(
pymysql
2020-06-10

封装一个python的pymysql操作类

最近使用pymysql写脚本的情况越来越多了,刚好整理,简单封装一个pymysql的操作类import pymysqlclass MysqlDB:def __init__(self, host=None, port=None, db=No
2022-12-25

python-pymysql

1.基本用法import pymysql#建立连接conn=pymysql.connect( host='localhost', port=3306, user='root', password='123456',
2023-01-31

如何封装一个python的pymysql操作类

这篇“如何封装一个python的pymysql操作类”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何封装一个python的
2023-07-04

详解PyMySQL插入字典类型的数据

在我们爬虫或者调API获取数据后,需要将数据存入到数据库中,如果数据是列表嵌套字典格式的话,一般做法是遍历列表,然后用字典生成对应的SQL语句再执行插入到表中。本文将介绍一种更加简便的方法来插入字典类型的数据。我们有如下数据列表,需要将该
2022-07-18

pymysql KeyError:25

在weibospider项目新建所有的表时遇到的错误:Traceback (most recent call last): File "/Library/Frameworks/Python.framework/Versions/3.6/l
2023-01-31

python3之pymysql

pymsql是Python中操作MySQL的模块并且只有在Python3.0版本中才存在,其使用方法和MySQLdb几乎相同。下载安装pymsql模块pip3 install pymysql操作前准备#1.创建数据库mysql> creat
2023-01-31

python pymysql存储

1 # _*_ coding:utf-8 _*_ 2 import requests 3 from bs4 import BeautifulSoup 4 import re 5 import pymysql 6 7 def create(
2023-01-30

python安装pymysql

1.通过pip进行安装 pip install pymsql2.验证安装是否成功 python import pymysql pymysql.VERSION
2023-01-31

【Python3】pymysql模块

1. 什么是 PyMySQL?PyMySQL 是在 Python3.x 版本中用于连接 MySQL 服务器的一个库,Python2中则使用mysqldb。PyMySQL 遵循 Python 数据库 API v2.0 规范,并包含了 pure
2023-01-31

Python的pymysql用法

使用pip安装pymysql 的方法pip install pymysql连接数据库conn = pymysql.connect(host="127.0.0.1", user="用户名", password="密码", database="数据库名", cha

	Python的pymysql用法
2017-03-03

pymysql模块的使用

pymysql的下载和使用之前我们都是通过MySQL自带的命令行客户端工具mysql来操作数据库,那如何在python程序中操作数据库呢?这就用到了pymysql模块,该模块本质就是一个套接字客户端软件,使用前需要事先安装(1)pymysq
2023-01-30

Python之元类ORM

什么是元类在Python中一切皆对象,类也是一个对象,实例对象由类创建出来的,类是由元类创建出来的。简而言之,用来创建类的类就叫元类(metaclass)。 函数type其实就是一个元类,type就是Python在背后用来创建所有类的元类。
2023-01-31

OSX下mysql、pymysql的安

OSX下mysql安装较为简单,mysql官网下载地址http://dev.mysql.com/downloads/mysql/选择OSX版本安装TIPS:默认新版mysql在OSX下的配置文件/etc/my.cnf不存在,其他默认路径下也
2023-01-31

python中的元类

目录 元类 什么是元类 自定义元类 其他 元类什么是元类我们创建一个类目的是为了创建该类的实例对象,而元类就是用来创建类的
2023-01-30

python 3 使用pymysql 连

pymysql 连接Inception ,在判断版本时会出现value error 问题。原因是pymysql通过‘.’进行分割,但是Inception的版本信息是这样的 ./mysql -V Ver 14.14 Distrib Incep
2023-01-31

编程热搜

目录