运用Python语言编写获取Linux基本系统信息(三):Python与数据库编程,把获取的信息存入数据库
运用Python语言编写获取Linux基本系统信息(三):Python与数据库编程
有关前两篇的链接:
运用Python语言编写获取Linux基本系统信息(一):获得Linux版本、内核、当前时间
运用Python语言编写获取Linux基本系统信息(二):文件系统使用情况获取
一、实验环境:
Python2.7.10、pycharm、VM虚拟机、CentOS6.3、mysql
二、MySQLdb模块:
MySQLdb模式是Python中专门连接MySQL数据库的模块,另外Python开发环境的搭建真心感觉比其他的麻烦好多。。。这次光安装这个MySQLdb这个模块就花了好长时间,遇到好多问题,不过幸好还是成功使用上了,稍后我会加上一篇我是怎么安装的教程,会列出我遇到的问题供大家参考。
三、实现:
这里先介绍一下数据库,我们使用的是安装在CentOS上的MySQL数据库。数据库的安装这里不做介绍。
在MySQL中我们把所有表放在名为linux的数据库中,数据库包含两张表:存放linux信息数据的linux表中,存放硬盘数据的fdisk表中

这两个表的SQL:
CREATE TABLE linux //linux表
(
os_version VARCHAR(1000) NOT NULL,
os_kernal VARCHAR(1000) not NULL,
os_data VARCHAR(1000) PRIMARY KEY,
) CREATE TABLE fdisk //fdisk表
(
f_date TIMESTAMP(14) NOT NULL,
filesystem VARCHAR(1000) NOT NULL,
rom VARCHAR(1000) not NULL,
used VARCHAR(1000) not NULL,
not_used VARCHAR(1000) not NULL,
used_per VARCHAR(1000) NOT NULL,
mount VARCHAR(1000) not NULL
)
所有对于表的操作都在一个py文件中,包括插入和查询操作
mysql_db.py
#coding=UTF-8
import MySQLdb
import _mysql_exceptions
createlinuxsql = """
CREATE TABLE linux
(
os_version VARCHAR(1000) NOT NULL,
os_kernal VARCHAR(1000) not NULL,
os_data VARCHAR(1000) PRIMARY KEY, )
"""
createfdisksql = """
CREATE TABLE fdisk
(
f_date TIMESTAMP(14) NOT NULL,
filesystem VARCHAR(1000) NOT NULL,
rom VARCHAR(1000) not NULL,
used VARCHAR(1000) not NULL,
not_used VARCHAR(1000) not NULL,
used_per VARCHAR(1000) NOT NULL,
mount VARCHAR(1000) not NULL
)
"""
class mysql:
def __init__(self):
try:
self.conn = MySQLdb.connect(host='192.168.179.129',user='root',passwd='ro',db='linux')
self.cur = self.conn.cursor()
except _mysql_exceptions.OperationalError,e:
print '数据库无法连接'
def __del__(self):
self.cur.close()
self.conn.commit()
self.conn.close()
def select(self):
try:
self.cur.execute("select * from linux")
for each in self.cur.fetchall():
print each
except _mysql_exceptions.ProgrammingError,e:
self.cur.execute(createlinuxsql)
def os_insert(self,version,kernal,data):
try:
self.cur.execute("insert into linux VALUES ('%s','%s','%s')"% (version,kernal,data))
except _mysql_exceptions.ProgrammingError,e:
self.cur.execute(createlinuxsql)
self.cur.execute("insert into linux VALUES ('%s','%s','%s')"% (version,kernal,data))
def fdisk_select(self):
try:
self.cur.execute("select * from fdisk")
print self.cur.fetchall()
except _mysql_exceptions.ProgrammingError,e:
self.cur.execute(createfdisksql)
def fdisk_insert(self,filesystemz,romz,usedz,nousedz,usedperz,mountz):
try:
self.cur.execute("insert into fdisk(filesystem,rom,used,not_used,used_per,mount) \
VALUES ('%s','%s','%s','%s','%s','%s')"% (filesystemz,\
romz,usedz,nousedz,usedperz,mountz))
except _mysql_exceptions.ProgrammingError,e:
self.cur.execute(createfdisksql)
self.cur.execute("insert into fdisk(filesystem,rom,used,not_used,used_per,mount) \
VALUES ('%s','%s','%s','%s','%s','%s')"% (filesystemz,\
romz,usedz,nousedz,usedperz,mountz))
不用去手动建立表,只要数据库存在会自动建立表的
同时对以前的一些代码进行了更新,更新只填写变动
os_info.py:
# coding=UTF-8
import linux_status
import os_info_in
from mysql_db import mysql
class os_info:
def __init__(self):
# self.linux_stat=linux_status.linux_status()
self.os_infos_in= os_info_in.os_info_in()
def os_info(self):
self.linux_stat=linux_status.linux_status()
self.linux_stat.os_version = self.os_infos_in.os_version()
self.linux_stat.os_kernal = self.os_infos_in.os_kernel()
self.linux_stat.os_date = self.os_infos_in.os_date()
return self.linux_stat
def os_in_mysql(self):
os_db=mysql()
os_db.os_insert(self.os_infos_in.os_version(),self.os_infos_in.os_kernel(),self.os_infos_in.os_date())
linux_fdisk.py:
def fdisk_mysql(self):
self.fdisk_mysql=mysql()
i=0
j=1
while j==1:
try:
self.fdisk_mysql.fdisk_insert(self.disk_info[i],self.disk_info[i+1],self.disk_info[i+2],\
self.disk_info[i+3],self.disk_info[i+4],self.disk_info[i+5])
i=i+6
except Exception,e:
j=0
四、结果展示:



mysql不支持显示中文,把linux改为英文就可以了(export LANG=en_US)


最后~
这个系列就先写到这吧~~等以后有啥新的想法会继续写的~~
欢迎大神加我QQ:707475486~备注:博客园就行~这样我有什么问题就可以很轻松的问了!大家一起进步~~~~~最近工作比较忙所以这一篇更得比较慢~
运用Python语言编写获取Linux基本系统信息(三):Python与数据库编程,把获取的信息存入数据库的更多相关文章
- 运用Python语言编写获取Linux基本系统信息(二):文件系统使用情况获取
本文跟着上一篇文章继续写,上一篇文章的链接 运用Python语言编写获取Linux基本系统信息(一):获得Linux版本.内核.当前时间 一.随便说说 获取文件系统使用情况的思路和上一篇获取主要系统是 ...
- Python语言编写BP神经网络
Python语言编写BP神经网络 2016年10月31日 16:42:44 ldy944758217 阅读数 3135 人工神经网络是一种经典的机器学习模型,随着深度学习的发展神经网络模型日益完善 ...
- 使用c语言实现在linux下的openssl客户端和服务器端编程
使用c语言实现在linux下的openssl客户端和服务器端编程 摘自:https://www.cnblogs.com/etangyushan/p/3679457.html 前几天组长让我实现一个使用 ...
- 尚学python课程---11、linux环境下安装python注意
尚学python课程---11.linux环境下安装python注意 一.总结 一句话总结: 准备安装依赖包:zlib.openssl:yum install zlib* openssl*:pytho ...
- 运用Python语言编写获取Linux基本系统信息(一):获得Linux版本、内核、当前时间
申请博客有一段时间了,然而到现在还一篇没有写过..... 主要因为没有想到需要写些什么,最近在学习Python语言,照着书上看了看最基础的东西,发现根本看不进去,而且光看的话今天看了觉得都理解懂了,过 ...
- Python语言应用解析,如何入门学Python?
Python在机器学习人工智能领域非常流行,可以说是算法工程师的标配编程语言.Python语言广泛应用在web开发.大数据开发.人工智能开发.机器学习.后端开发等领域之中,近几年Python语言的趋势 ...
- c#代码 天气接口 一分钟搞懂你的博客为什么没人看 看完python这段爬虫代码,java流泪了c#沉默了 图片二进制转换与存入数据库相关 C#7.0--引用返回值和引用局部变量 JS直接调用C#后台方法(ajax调用) Linq To Json SqlServer 递归查询
天气预报的程序.程序并不难. 看到这个需求第一个想法就是只要找到合适天气预报接口一切都是小意思,说干就干,立马跟学生沟通价格. 不过谈报价的过程中,差点没让我一口老血喷键盘上,话说我们程序猿的人 ...
- 用python语言编写网络爬虫
本文主要用到python3自带的urllib模块编写轻量级的简单爬虫.至于怎么定位一个网页中具体元素的url可自行百度火狐浏览器的firebug插件或者谷歌浏览器的自带方法. 1.访问一个网址 re= ...
- 使用python语言编写脚本控制freeswitch总结
1. 在Linux环境下已经安装了freeswitch,(没安装freeswitch,请安装说明文档) 2. 进入源代码目录 cd libs/esl 目录下 首先安装 yum install p ...
随机推荐
- 侯捷C++ Type traits(类型萃取
泛型編程編出來的代碼,適用於任何「吻合某種條件限制」的資料型別.這已成為撰寫可復用代碼時的一個重要選擇.然而,總有一些時候,泛型不夠好 — 有時候是因為不同的型別差距過大,難以產生一致的泛化實作版本. ...
- 转:trie树--详解
前几天学习了并查集和trie树,这里总结一下trie. 本文讨论一棵最简单的trie树,基于英文26个字母组成的字符串,讨论插入字符串.判断前缀是否存在.查找字符串等基本操作:至于trie树的删除单个 ...
- CCNA实验(10) -- Access List
使用包过滤技术在路由器上读取三层及四层报头的信息如源地址.目的地址.源端口.目的端口根据预先定义好的规则对包进行过滤 三种类型:1.标准ACL:表号范围1-99或1300-1999.仅对源IP地址进行 ...
- BZOJ 3498 PA2009 Cakes(三元环处理)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3498 [题目大意] N个点m条边,每个点有一个点权a. 对于任意一个三元环(j,j,k ...
- Codeforces 700B Connecting Universities(树形DP)
[题目链接] http://codeforces.com/problemset/problem/700/B [题目大意] 给出 一棵n个节点的树, 现在在这棵树上选取2*k个点,两两配对,使得其配对的 ...
- 在头文件声明全局变量和创建extern
在头文件声明全局变量和创建extern 问题: 是否有简单的方法,在头文件里定义我的变量,同时也为它们创建extern定义? 回答: 是的.尽管这不是必需的,使用正确的宏和一个头文件还是很容易实现的. ...
- GridView行编辑、更新、取消、删除事件使用方法
注意:当启用编辑button时,点击编辑button后会使一整行都切换成文本框.为了是一行中的一部分是文本框,须要把以整行的全部列都转换成模板,然后删掉编辑模板中的代码.这样就能使你想编辑的列转换成文 ...
- css3的一些属性
以前还没有注意过css的一些属性,近期发现有一些样式很好用,现在整理一遍. CSS3 动画属性 @keyframes : 规定动画 可以通过keyframes 改变一个块的样式当然这是要配合anima ...
- js获取智能机浏览器版本信息
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> ...
- ios sdk的制作
制作sdk的主要目的是将自己的code通过接口提供给其他应用使用.接下来介绍.a 静态库的制作注意事项: 1.首先.a文件的静态库要进行随时的测试,因此需要将其放入应用中(创建一个应用,再创建一个.a ...