第二课会介绍Python中的一些变量的使用、列表、元组、字典等一些详细内容。。。篇幅会比较多。。。因此在整理中。。。

先跳过第二课。。。直接来第三课。。Python中面向对象的学习以及与mysql数据库的连接!!!

Python也是一门面向对象语言,,,开始之前不得不夸下我真的。。。真的。。真的好喜欢Python啊啊啊!!!

下面我们就一起进入Python的对象世界把。。。

  Python中如何去定义、创建到使用一个类???

闲话不多说。。。看代码才是硬道理。。。

Python--类创建

'''
@desc:基本类定义
@author:Jimly
@date:20160325
'''
class Student: stuNum = 0 #公开变量
__num = 0 #私有变量 使用两个下划线开头定义的变量 def __init__(self, name, age):
self.name = name
self.age = age
Student.stuNum += 1 def showStudent(self):
print(self.name, ' ', self.age) '创建学生对象'
stu = Student("ZhangSan", 20)
stu1 = Student("LiSi", 21) '访问类中的属性'
stu.showStudent()
print('stuNum: %d' % Student.stuNum)
'程序报错 因为num属性为私有属性'
#print('stuNum: %d' % Student.num) print('stu name:', getattr(stu, 'name')) #返回name属性的值,如果不存在运行会报错
print('stu has sex?', hasattr(stu, 'sex')) #判断stu对象是否存在sex属性,存在返回True,不存在返回False
setattr(stu, 'sex', 'man') #设置sex属性值,如果不存在则创建一个属性
print('stu sex:', getattr(stu, 'sex'))
delattr(stu, 'sex') #删除一个属性
print('stu sex:', hasattr(stu, 'sex'))

程序输出:

ZhangSan   20
stuNum: 2
stu name: ZhangSan
stu has sex? False
stu sex: man
stu sex: False

  不像JAVA语言。。。Python是支持多继承滴。。。如class A(P1, P2, P3......)。。。

其中类P1,P2,P3就是父类。。。A就是继承了这么多父类的子类。。。

还有就是子类的构造方法中是不会默认调用父类的构造方法的。。。这一点也和JAVA有点出入。。。

Python--继承类

'''
@desc:Python继承
@author:Jimly
@date:20160325
'''
class Grand: def __init__(self):
print('Grand Constructor') def say(self):
print('I am Grand') class Parent: def __init__(self):
print('Parent Constructor') def method(self):
print('Parent method') class Child(Parent, Grand):  # Child类继承Parent类和Grand类,,,Python支持多继承 def __init__(self):
# Grand.__init__(self)
# Parent.__init__(self)
print('Child Constructor') def method(self):  # 重写Parent类中的method方法
print('Child method') child = Child()
child.method()
child.say()

程序运行输出:

Child Constructor
Child method
I am Grand

Python--数据库连接

  想要通过Python代码连接mysql数据库,,,有MySQLdb和pymysql两种库可以用来连接mysql。。。

   但是Python3之后不再支持MySQLdb。。。由于我装的是Python 3.4.3.。因此只能用pymysql库咯。。。

    附:查看Python安装的版本  =》  在DOS窗口敲入命令:python --version

  

  首先在python官网下载ez_setup.py文件。。。如若链接失效、请访问https://pypi.python.org/pypi/setuptools/

   下载完ez_setup.py文件后,,,执行该文件。。。

   执行命令:  python ez_setup.py  如下图所示

    

   执行完之后会在Python的安装目录下的Scripts文件夹下生成一个easy_install.exe文件。。。如下图所示

  

   进入到该文件夹中。。执行命令:  easy_install.exe pymysql3  来安装pymysql3服务如下图所示

    

   pymysql3服务安装完之后,,,就可以动手写python连接mysql服务的程序咯。。。

  

实例代码如下:--查询案列

import pymysql

db = pymysql.connect(user='root', passwd='root',host='localhost', db='my_form')

sql = "select * \
from form_frame" cursor = db.cursor() cursor.execute(sql) for r in cursor:
print('id:', r[0], ' rows:', r[1], ' cols:', r[2]) cursor.close() db.close()

程序运行结果:

id: 5  rows: 111  cols: 111
id: 6 rows: 222 cols: 222
id: 7 rows: 333 cols: 333
id: 11 rows: 2015 cols: 111
id: 12 rows: 2015 cols: 222
id: 13 rows: 2015 cols: 333
id: 29 rows: 2015 cols: 111
id: 30 rows: 2015 cols: 222
id: 31 rows: 2015 cols: 333

注:import pymysql 可用别名替代、、、如:import pymysql as mysqldb 其中mysqldb可自定义的别名。。。

  此时db = pymysql.connect(user='root', passwd='root',host='localhost', db='my_form')需改为

    db = mysqldb.connect(user='root', passwd='root',host='localhost', db='my_form')

 新增案列代码:

import pymysql

db = pymysql.connect(user='root', passwd='root',host='localhost', db='my_form')

sql = "insert into form_frame(cols, rows) values(101, 201),(102, 202)"

try:
cursor = db.cursor() res = cursor.execute(sql) db.commit() print(res) #res为返回新增的记录条数 except:
db.rollback() cursor.close() db.close()

程序输出:2

  好了。。。今天就到这里了。。。

与Python Falling In Love_Python跨台阶(面向对象)的更多相关文章

  1. 与Python Falling In Love_Python跨台阶(环境搭建)

    Python--环境搭建 首先需要下载python安装包,官网下载地址:https://www.python.org/downloads/ 下载完直接点击安装... 安装完后就可以配置环境变量咯^_^ ...

  2. Python黑帽编程2.9 面向对象编程

    Python黑帽编程2.9 面向对象编程 我个人认为,计算机语言的发展,有两个方向,一个是从低到高的发展过程,在这个过程中,语言的思考和解决问题的方式是面向硬件的.硬件本质上处理的是信号,在此基础上, ...

  3. python学习笔记-(十)面向对象基础

    面向对象相关知识简介 类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例. 类变量:类变量在整个实例化的对象中是公用的.类变量定义 ...

  4. Python 第六篇(上):面向对象编程初级篇

    面向:过程.函数.对象: 面向过程:根据业务逻辑从上到下写垒代码! 面向过程的编程弊:每次调用的时候都的重写,代码特别长,代码重用性没有,每次增加新功能所有的代码都的修改!那有什么办法解决上面出现的弊 ...

  5. Python学习系列(八)( 面向对象基础)

     Python学习系列(八)( 面向对象基础) Python学习系列(七)( 数据库编程) 一,面向对象 1,域:属于一个对象或类的变量.有两种类型,即实例变量—属于每个实例/类的对象:类变量—属于类 ...

  6. python系列十六:Python3 面向对象

    #!/usr/bin/python #-*-coding:gbk-*- #Python3 面向对象 '''面向对象技术简介    类(Class): 用来描述具有相同的属性和方法的对象的集合.它定义了 ...

  7. python学习-第四天补充-面向对象

    python学习-第四天补充-面向对象 python 私有 --name mangling(名字修改.名字) 在命名时,通过使用两个下划线作为开头,可以使得这个变量或者函数编程私有的,但是这个其实的p ...

  8. Python匹马行天下之面向对象

    概述 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 面向过程编程最易被初学 ...

  9. 2016年终总结--一个Python程序猿的跨界之旅

    时间过得真快.感觉15年年终总结刚写完,16年就结束了.看了blog,16年就写了可怜的8篇,对我来说16年还算顺风顺水. 真正可能出乎意料的是年底我离开了呆了2年半的龙图游戏,临时放弃了用了3年半的 ...

随机推荐

  1. DGbroker主备切换

    1.检查DG是否正常 DGMGRL> show configuration; Configuration - dgc Protection Mode: MaxProtection Databas ...

  2. python基础(四)运算

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! Python的运算符和其他语言类似 (我们暂时只了解这些运算符的基本用法,方便我们 ...

  3. dpdk在虚拟机上出错处理

    目录 1. 所用系统与软件版本 2. 虚拟机配置 3. Ubuntu 12.04上的配置 3.1 准备 3.2 通过setup脚本进行配置 3.3 通过命令配置 4. CentOS 7.0上的配置 4 ...

  4. jquery常用方法

    一.多个按钮绑定同一事件 $("#index_svip,#index_svip_renew").click(function() { seajs.use(['svipLayer'] ...

  5. html5新增及废除属性

    html5中,在新增加和废除很多元素的同时,也增加和废除了很多属性. 一.新增属性 1.表单属性 a.autofocus 对input[所有类型].select.textarea与button指定au ...

  6. git 学习使用总结一(本地操作)

    通过几天的学习,熟悉了 git 的一些常用命令,要用熟练和操作更复杂的功能还必须继续学习.不过 git 作为工具,它是用来提高我们的工作效率的工具,系统的学习之后可以暂且放放,等到以后实际项目中用到了 ...

  7. Unity Ragdoll(布娃娃系统)

    逼真的动作如何实现的? 在一些游戏中当NPC或玩家死亡的时候,死亡的肢体动作十分逼真,这一物理现象如何用Unity来实现呢?Unity物理引擎中的Ragdoll系统,可以用来创建这种效果,具体请参阅以 ...

  8. IOS第五课——Gesture and TableView

    这一次我们要学习Gesture.TableView.AlertView三种技术. 一.Gesture 在iOS中,可以使用系统内置的手势识别(GestureRecognizer),也可以创建自己的手势 ...

  9. HTML 学习笔记 JavaScript (函数)

    函数是由事件驱动的或者当他被调用时执行的可重复使用的代码块 实例 <!DOCTYPE html> <html> <head> <script> func ...

  10. 两个经典的Oracle触发器示例(轉)

    [案例一] 题目:--触发器:--添加员工信息,流水号作为自动编号(通过序列生成),--并且判断如果工资小于0,则改为0;如果大于10000,则改为10000. CREATE TABLE emp2(e ...