将一些相同特征和动作的成为类,现有类才能创建对象,对象就是特征和动作的结合体

类:把一类事物的相同特征和动作整合到一起就是类。类是一个抽象概念

对象:就是基于类而创建的一个具的事物(具体存在的),也是特征和动作给的结合

类是用来描述 一类事物,类的对象指的是这一类书屋中的一个个个体,是事物就要有属性属性分为

1:数据属性:就是变量

2:函数属性:就是函数,在面向对象里通常称为方法

注意:::类和对象均用点来访问自己的属性

class Chinese:
'这是一个中国人'
dang='共青团'
def sui_di_tu_tan():
print('正在吐')
#调用这个函数一定要加参数,只不过还没定义参数的意义
def cha_dui(self):
print('插到了前面')
#数据属性
print(Chinese.dang)
#函数属性
Chinese.sui_di_tu_tan() print(dir(Chinese))
#查看类的属性字典
print('=========================================')
print(Chinese.__dict__)
print('=============================================')
print(Chinese.__dict__['dang'])
print('=========================================')
print(Chinese.cha_dui(1))
print('==============================')
Chinese.__dict__['sui_di_tu_tan']()
Chinese.__dict__['cha_dui']("you") 结果:
共青团
正在吐
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'cha_dui', 'dang', 'sui_di_tu_tan']
=========================================
{'__module__': '__main__', '__doc__': '这是一个中国人', 'dang': '共青团', 'sui_di_tu_tan': <function Chinese.sui_di_tu_tan at 0x7f7d87a91158>, 'cha_dui': <function Chinese.cha_dui at 0x7f7d87a911e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>}
=============================================
共青团
=========================================
插到了前面
None
==============================
正在吐
插到了前面

对象由类实例化而来,类实例化的结果称为一个实例或者称为一个对象

class Chinese:
'这是一个中国人'
dang='共青团'
def sui_di_tu_tan():
print('正在吐')
def cha_dui(self):
print('%s插到了前面' %self.名字)
#初始化:__init__定制对象的属性,__init__会自动return所以要是自己加上return回报错
def __init__(self,name,age,gender):
print('初始化开始')
print('-------------')
print(self)#========>p1
print('-------------')
self.名字=name #p1.名字=name
self.年龄=age #p1.年龄=age
self.性别=gender #p1.性别=gender
print('初始化结束')
#class自动帮你return了
def eat_foot(self,food):
print('%s is eating %s' % (self.名字,food))
#实例化会出发__init__函数运行
p1 = Chinese('charon',12,'F')
print(p1.__dict__)
print(p1.名字)
#p1产生的字典由__init__产生,p1调用dang在__init__作用域没找到,就去外一层Chinese作用域找dang
print(p1.dang)
#print(Chinese.__dict__)
Chinese.sui_di_tu_tan()
Chinese.cha_dui(p1)
#p1.sui_di_tu_tan()
p1.cha_dui()
#与self内春地址相同
print(p1)
p1.eat_foot('shit')
print('=========================================')
p2 = Chinese('pluto',100,'F')
p2.eat_foot('apple') 结果:
China
Japan
{'name': 'charon'}
Japan
eventment
eventment
{'__module__': '__main__', 'country': 'Japan', '__init__': <function Chinese.__init__ at 0x7fc8ed2ff158>, 'paly_ball': <function Chinese.paly_ball at 0x7fc8ed2ff1e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None, 'dang': 'eventment'}
===================================================
{'__module__': '__main__', 'country': 'Japan', '__init__': <function Chinese.__init__ at 0x7fc8ed2ff158>, 'paly_ball': <function Chinese.paly_ball at 0x7fc8ed2ff1e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None}

类的增删改查

# -*- coding:utf8 -*-
class Chinese:
country = 'China'
def __init__(self,name):
self.name=name
def paly_ball(self,ball):
print('%s in playing %s' % (self.name,ball))
#查看
print(Chinese.country)
#修改
Chinese.country = 'Japan'
print(Chinese.country)
#用这个类生成一个实例
p1 = Chinese('charon')
print(p1.__dict__)
print(p1.country)
#增加
Chinese.dang='eventment'
print(Chinese.dang)
print(p1.dang)
#删除
#del Chinese.dang
print(Chinese.__dict__)
print('===================================================')
del Chinese.dang
print(Chinese.__dict__) 结果:
China
Japan
{'name': 'charon'}
Japan
eventment
eventment
{'__module__': '__main__', 'country': 'Japan', '__init__': <function Chinese.__init__ at 0x7f29a1607158>, 'paly_ball': <function Chinese.paly_ball at 0x7f29a16071e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None, 'dang': 'eventment'}
===================================================
{'__module__': '__main__', 'country': 'Japan', '__init__': <function Chinese.__init__ at 0x7f29a1607158>, 'paly_ball': <function Chinese.paly_ball at 0x7f29a16071e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None}

实例属性增删改查

class Chinese:
country='China'
def __init__(self,name):
self.name=name
def paly_ball(self,ball):
print('%s 正在打 %s' % (self.name,ball))
#生成一个实例
p1 = Chinese('charon')
#查看实例属性字典
print(p1.__dict__) #查看实例属性
print(p1.name)
print(p1.paly_ball)
p1.paly_ball('football')
#增加实例属性
p1.age = 18
print(p1.__dict__)
print(p1.age)
#属性分为有函数属性跟数据属性
#实例只有数据属性,他的函数属性是调类的
#修改实例属性
p1.age=200
print(p1.__dict__)
print(p1.age)
#删除
del p1.age
print(p1.__dict__) 结果:
{'name': 'charon'}
charon
<bound method Chinese.paly_ball of <__main__.Chinese object at 0x7fafb2db8550>>
charon 正在打 football
{'name': 'charon', 'age': 18}
18
{'name': 'charon', 'age': 200}
200
{'name': 'charon'}

对象和实例属性

# class Chinese:
# country='China'
# def __init__(self,name):
# self.name=name
# def paly_ball(self,ball):
# print('%s 正在打 %s' % (self.name,ball))
# p1=Chinese('charon')
# print(p1.country)
# p1.country='Japan'
# #print(p1.__dict__)
# #print(Chinese.__dict__)
# print(p1.country)
# print(Chinese.country)
# print('类的--->',Chinese.country)
# print('实例的--->',p1.country) # class Chinese:
# country = '中国'
# def __init__(self,name):
# self.name=name
#
# def play_ball(self,ball):
# print('%s 正在打 %s' %(self.name,ball))
# p1=Chinese('alex')
# print(p1.country) country='中国-------------------'
class Chinese:
country='中国'
def __init__(self,name):
self.name=name
#这个country是个变量,类是点加country
print('--->',country) def play_ball(self,ball):
print('%s 正在打 %s' %(self.name,ball)) #print(Chinese.__dict__)
#print(Chinese.country)
p1=Chinese('alex')
print(Chinese.country)
print(Chinese.__dict__) 结果:
---> 中国-------------------
中国
{'__module__': '__main__', 'country': '中国', '__init__': <function Chinese.__init__ at 0x7f298ab72158>, 'play_ball': <function Chinese.play_ball at 0x7f298ab721e0>, '__dict__': <attribute '__dict__' of 'Chinese' objects>, '__weakref__': <attribute '__weakref__' of 'Chinese' objects>, '__doc__': None}

换个姿势搞你,就不信你不爽

class Chinese:
country='China'
l=['a','b']
def __init__(self,name):
self.name=name
print(self.name) def play_ball(self,ball):
print('%s 正在打 %s' %(self.name,ball)) p1=Chinese('charon')
# p1.l=['a','b','c']
# print(p1.l)
# print(Chinese.l)
# print(Chinese.__dict__)
print(p1.l)
p1.l.append('c')
print(p1.l)
print(p1.__dict__)
print(Chinese.l) 结果:
charon
['a', 'b']
['a', 'b', 'c']
{'name': 'charon'}
['a', 'b', 'c']

day24 Pythonpython 面向对象设计 类的更多相关文章

  1. day24:面向对象设计与面向对象编程、类和对象

    一.三大编程范式: 面向过程: 面向函数: 面向对象: 二.程序的进化论: 1.编程最开始就是无组织无结构,从简单控制流中按步写指令 2.从上述的指令中提取重复的代码块或逻辑,组织到一起(比方说,你定 ...

  2. matlab面向对象设计---类的概念和使用

    代码: classdef MadgwickAHRS < handle %MADGWICKAHRS Implementation of Madgwick's IMU and AHRS algori ...

  3. python函数的面向对象——面向对象设计

    通过几个函数式编号演进,理解面向对象设计 def01.py dog1 = { 'name':'元昊', 'gender':'母', 'type':'藏獒' } dog2 = { 'name':'李李' ...

  4. day24 面向对象设计part1

    #!/usr/bin/env python # -*- coding:utf-8 -*- # ----------------------------------------------------- ...

  5. UML类图与面向对象设计原则

    1. 引言     从大一开始学习编程,到如今也已经有两年了.从最初学习的Html,Js,JaveSe,再到JavaEE,Android,自己也能写一些玩具.学习过程中也无意识的了解了一些所谓的设计模 ...

  6. <九>面向对象分析之UML核心元素之设计类,类,属性,方法,可见性

    设计类

  7. C#基础第八天-作业答案-设计类-面向对象方式实现两个帐户之间转账

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  8. C#基础第八天-作业-设计类-面向对象方式实现两个帐户之间转账

    要求1:完成以下两种账户类型的编码.银行的客户分为两大类:储蓄账户(SavingAccount)和信用账户(CreditAccount),两种的账户类型的区别在于:储蓄账户不允许透支,而信用账户可以透 ...

  9. Virtools元素、类和面向对象设计

    无意中发现了在某个不存在的网站( https://sites.google.com )上,还存有09年写的一些半成品教材,下面这篇文章就是其中一部分. 概述 Virtools将元素(Element)组 ...

随机推荐

  1. 偏门却又实用的 CSS 样式

    ::-Webkit-Input-Placeholder input 的 H5 placeholder 属性,很好用,但不能直接改这个文字颜色,所以目前的解决方法就是用::input-placehold ...

  2. 移动前端—H5实现图片先压缩再上传

    在做移动端图片上传的时候,用户传的都是手机本地图片,而本地图片一般都相对比较大,拿iphone6来说,平时拍很多图片都是一两M的,如果直接这样上传,那图片就太大了,如果用户用的是移动流量,完全把图片上 ...

  3. 13张动图助你彻底看懂马尔科夫链、PCA和条件概率!

    13张动图助你彻底看懂马尔科夫链.PCA和条件概率! https://mp.weixin.qq.com/s/ll2EX_Vyl6HA4qX07NyJbA [ 导读 ] 马尔科夫链.主成分分析以及条件概 ...

  4. SuperMap-iServer过滤请求返回值

    目的: iServer发布的arcgis地图服务中,由于tileinfo参数为null,导致用arcgis-ios客户端开发的APP闪退.通过过滤器将get请求的返回值修改 代码: package c ...

  5. odoo:开源 ERP/CRM 入门与实践

    看了这张图,或许你对odoo有了一些兴趣. 这次就是和大家一起交流开源ERP/CRM系统:odoo 对以下读者有帮助:研发.产品.项目.市场.服务.运营.管理等. 一.背景趋势 社交网络.电商O2O: ...

  6. Nginx 限制并发连接和并发请求数配置

    Nginx限制并发连接和并发请求数配置   by:授客  QQ:1033553122   测试环境 nginx-1.10.0 配置介绍 查看是否内置模块 # pwd /mnt/nginx-1.10.0 ...

  7. mysql之事务管理

    本文内容: 什么是事务管理 事务管理操作 回滚点 默认的事务管理 首发日期:2018-04-18 什么是事务管理: 可以把一系列要执行的操作称为事务,而事务管理就是管理这些操作要么完全执行,要么完全不 ...

  8. matlab练习程序(点云表面法向量)

    思路还是很容易想到的: 1.首先使用KD树寻找当前点邻域的N个点,这里取了10个,直接调用了vlfeat. 2.用最小二乘估计当前邻域点组成的平面,得到法向量. 3.根据当前邻域点平均值确定邻域质心, ...

  9. Python textwrap模块(文本包装和填充)

    textwrap提供函数wrap().fill().indent().dedent()和以及TextWrapper类. 通常包装或者填充一两个字符串使用wrap()和fill().其他情况使用Text ...

  10. linux卸载openjdk

    本来不想写的网上的东西罗嗦死了 sudo apt-get purge openjdk*