python rowcount(如何用python最快的获取大文件的最后几行)

2024-07-22 14:34:15 5

python rowcount(如何用python最快的获取大文件的最后几行)

本文目录

如何用python最快的获取大文件的最后几行

工作中经常会遇到处理日志文件的问题:为了得到日志的最新状态,我们需要获取日志文件的最后部分行来做判断。那么,这种情况下我们应该怎么做呢?1)常规方法:从前往后依次读取步骤:open打开日志文件。读取文件,获取文件的总行数。遍历所有行,提取指定行的数据。优点:简单,方便缺点:当文件大了以后时间太慢,无法忍受2)推荐方法:步骤:open打开日志文件。移动文件读取指针到文件末尾。从后往前移动指针直到合适的位置。读取文件,提取指定行的数据。优点:时间相对固定,适合处理大文件示例: view plain copylogFile = open(’logFilePath.log’, ’r’) logFile.seek(0,2) logFile.seek(-1000000,2) rowCount = 0 for row in logFile.readlines(): pass seek():移动文件读取指针到指定位置tell():返回文件读取指针的位置seek()的三种模式:(1)f.seek(p,0) 移动当文件第p个字节处,绝对位置(2)f.seek(p,1) 移动到相对于当前位置之后的p个字节(3)f.seek(p,2) 移动到相对文章尾之后的p个字节

如何用python操作数据库表

# -*- coding:utf8 -*-import MySQLdbconn = MySQLdb.connect(                        #此处连接数据库信息host = ’127.0.0.1’,port = 3306,user = ’root’,passwd = ’root’,db = ’python’,charset = ’utf8’)key1 = raw_input()value2 = raw_input()cursor = conn.cursor()try:#cursor.execute(’SELECT * from test’)  # 查询数据库内容#print cursor.rowcount    #输出改变行数cursor.execute("insert into test (’key1’) values (value2)")  # 增加数据库内容#cursor.execute("update test set name = ’lisi’ where name = ’zhangsan’")   # 更新数据库内容#cursor.execute("delete from test where name = ’lisi’")  #删除数据库内容conn.commit()except Exception as e:# 执行出错回滚数据print econn.rollback()cursor.closeconn.close

Python批量插入问题

s = 10000list = c=0sql = """insert into customer(id,name,company_id,sharding_id) values(:col1,:col2,:col3,:col4)"""for k in range(0,12): i = 2000000 + k; list.append() #list1.append() if c == 10: cursor = conn.cursor() #print list cursor.executemany(sql,list) conn.commit() c = 0 print("insert into customer many data cursor:"+str(i)) list= c = c + 1 if s==10000: s = 10010 elif s==10010: s = 10020 elif s== 10020: s = 10030 elif s==10030: s = 10000if i》0: cursor.executemany(sql,list) conn.commit()程序调试通过,改了 2个地方 1.sql = """insert into customer(id,name,company_id,sharding_id) values(:col1,:col2,:col3,:col4)"""2.list.clear()---》list=

python怎么处理mysql dmp文件

在Windows平台上安装mysql模块用于Python开发

用python连接mysql的时候,需要用的安装版本,源码版本容易有错误提示。下边是打包了32与64版本。 MySQL-python-1.2.3.win32-py2.7.exe MySQL-python-1.2.3.win-amd64-py2.7.exe实例 1、取得 MYSQL 的版本

# -*- coding: UTF-8 -*-#安装 MYSQL DB for pythonimport MySQLdb as mdbcon = Nonetry:#连接 mysql 的方法: connect(’ip’,’user’,’password’,’dbname’)con = mdb.connect(’localhost’, ’root’,’root’, ’test’);#所有的查询,都在连接 con 的一个模块 cursor 上面运行的cur = con.cursor()#执行一个查询cur.execute("SELECT VERSION()")#取得上个查询的结果,是单个结果data = cur.fetchone()print "Database version : %s " % datafinally:if con:#无论如何,连接记得关闭con.close()

实例 2、创建一个表并且插入数据

import MySQLdb as mdbimport sys#将 con 设定为全局连接con = mdb.connect(’localhost’, ’root’, ’root’, ’test’);with con:#获取连接的 cursor,只有获取了 cursor,我们才能进行各种操作cur = con.cursor()#创建一个数据表 writers(id,name)cur.execute("CREATE TABLE IF NOT EXISTS \Writers(Id INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(25))")#以下插入了 5 条数据cur.execute("INSERT INTO Writers(Name) VALUES(’Jack London’)")cur.execute("INSERT INTO Writers(Name) VALUES(’Honore de Balzac’)")cur.execute("INSERT INTO Writers(Name) VALUES(’Lion Feuchtwanger’)")cur.execute("INSERT INTO Writers(Name) VALUES(’Emile Zola’)")cur.execute("INSERT INTO Writers(Name) VALUES(’Truman Capote’)")

实例 3、 python 使用 slect 获取 mysql 的数据并遍历

import MySQLdb as mdbimport sys#连接 mysql,获取连接的对象con = mdb.connect(’localhost’, ’root’, ’root’, ’test’);with con:#仍然是,第一步要获取连接的 cursor 对象,用于执行查询cur = con.cursor()#类似于其他语言的 query 函数, execute 是 python 中的执行查询函数cur.execute("SELECT * FROM Writers")#使用 fetchall 函数,将结果集(多维元组)存入 rows 里面rows = cur.fetchall()#依次遍历结果集,发现每个元素,就是表中的一条记录,用一个元组来显示for row in rows:print row

运行结果:

(1L, ‘Jack London’)(2L, ‘Honore de Balzac’)(3L, ‘Lion Feuchtwanger’)(4L, ‘Emile Zola’)(5L, ‘Truman Capote’)上面的代码,用来将所有的结果取出,不过打印的时候是每行一个元祖打印,现在我们使用方法,取出其中的单个数据:

import MySQLdb as mdbimport sys#获取 mysql 的链接对象con = mdb.connect(’localhost’, ’root’, ’root’, ’test’);with con:#获取执行查询的对象cur = con.cursor()#执行那个查询,这里用的是 select 语句cur.execute("SELECT * FROM Writers")#使用 cur.rowcount 获取结果集的条数numrows = int(cur.rowcount)#循环 numrows 次,每次取出一行数据for i in range(numrows):#每次取出一行,放到 row 中,这是一个元组(id,name)row = cur.fetchone()#直接输出两个元素print row

运行结果:

1 Jack London2 Honore de Balzac3 Lion Feuchtwanger4 Emile Zola5 Truman Capote实例 4、使用字典 cursor 取得结果集(可以使用表字段名字访问值)

import MySQLdb as mdbimport sys#获得 mysql 查询的链接对象con = mdb.connect(’localhost’, ’root’, ’root’, ’test’)with con:#获取连接上的字典 cursor,注意获取的方法,#每一个 cursor 其实都是 cursor 的子类cur = con.cursor(mdb.cursors.DictCursor)#执行语句不变cur.execute("SELECT * FROM Writers")#获取数据方法不变rows = cur.fetchall()#遍历数据也不变(比上一个更直接一点)for row in rows:#这里,可以使用键值对的方法,由键名字来获取数据print "%s %s" % (row)

实例 5、获取单个表的字段名和信息的方法

import MySQLdb as mdbimport sys#获取数据库的链接对象con = mdb.connect(’localhost’, ’root’, ’root’, ’test’)with con:#获取普通的查询 cursorcur = con.cursor()cur.execute("SELECT * FROM Writers")rows = cur.fetchall()#获取连接对象的描述信息desc = cur.descriptionprint ’cur.description:’,desc#打印表头,就是字段名字print "%s %3s" % (desc)for row in rows:#打印结果print "%2s %3s" % row

运行结果:

cur.description: ((‘Id’, 3, 1, 11, 11, 0, 0), (‘Name’, 253, 17, 25, 25, 0, 1))Id Name1 Jack London2 Honore de Balzac3 Lion Feuchtwanger4 Emile Zola5 Truman Capote实例 6、使用 Prepared statements 执行查询(更安全方便)

import MySQLdb as mdbimport syscon = mdb.connect(’localhost’, ’root’, ’root’, ’test’)with con:cur = con.cursor()#我们看到,这里可以通过写一个可以组装的 sql 语句来进行cur.execute("UPDATE Writers SET Name = %s WHERE Id = %s",("Guy de Maupasant", "4"))#使用 cur.rowcount 获取影响了多少行print "Number of rows updated: %d" % cur.rowcount

结果:Number of rows updated: 1

实例 7、把图片用二进制存入 MYSQL

有人喜欢把图片存入 MYSQL(这种做法貌似很少吧),我看大部分的程序,图片都是存放在服务器上的文件,数据库中存的只是图片的地址而已,不过 MYSQL 是支持把图片存入数据库的,也相应的有一个专门的字段 BLOB (Binary Large Object),即较大的二进制对象字段,请看如下程序,注意测试图片自己随便找一个,地址要正确: 首先,在数据库中创建一个表,用于存放图片:

复制代码代码如下:

CREATE TABLE Images(Id INT PRIMARY KEY AUTO_INCREMENT, Data MEDIUMBLOB);

然后运行如下 PYTHON 代码进行:

import MySQLdb as mdbimport systry:#用读文件模式打开图片fin = open("../web.jpg")#将文本读入 img 对象中img = fin.read()#关闭文件fin.close()except IOError, e:#如果出错,打印错误信息print "Error %d: %s" % (e.args)sys.exit(1)try:#链接 mysql,获取对象conn = mdb.connect(host=’localhost’,user=’root’,passwd=’root’,db=’test’)#获取执行 cursorcursor = conn.cursor()#直接将数据作为字符串,插入数据库cursor.execute("INSERT INTO Images SET Data=’%s’" %mdb.escape_string(img))#提交数据conn.commit()#提交之后,再关闭 cursor 和链接cursor.close()conn.close()except mdb.Error, e:#若出现异常,打印信息print "Error %d: %s" % (e.args)sys.exit(1)

实例 8、从数据库中把图片读出来

import MySQLdb as mdbimport systry:#连接 mysql,获取连接的对象conn = mdb.connect(’localhost’, ’root’, ’root’, ’test’);cursor = conn.cursor()#执行查询该图片字段的 SQLcursor.execute("SELECT Data FROM Images LIMIT 1")#使用二进制写文件的方法,打开一个图片文件,若不存在则自动创建fout = open(’image.png’,’wb’)#直接将数据如文件fout.write(cursor.fetchone())#关闭写入的文件fout.close()#释放查询数据的资源cursor.close()conn.close()except IOError, e:#捕获 IO 的异常 ,主要是文件写入会发生错误print "Error %d: %s" % (e.args)sys.exit(1)

实例 9、使用 Transaction 即事务(手动提交,自动回滚)

import MySQLdb as mdbimport systry:#连接 mysql,获取连接的对象conn = mdb.connect(’localhost’, ’root’, ’root’, ’test’);cursor = conn.cursor()#如果某个数据库支持事务,会自动开启#这里用的是 MYSQL,所以会自动开启事务(若是 MYISM 引擎则不会)cursor.execute("UPDATE Writers SET Name = %s WHERE Id = %s",("Leo Tolstoy", "1"))cursor.execute("UPDATE Writers SET Name = %s WHERE Id = %s",("Boris Pasternak", "2"))cursor.execute("UPDATE Writer SET Name = %s WHERE Id = %s",("Leonid Leonov", "3"))#事务的特性 1、原子性的手动提交conn.commit()cursor.close()conn.close()except mdb.Error, e:#如果出现了错误,那么可以回滚,就是上面的三条语句要么执行,要么都不执行conn.rollback()print "Error %d: %s" % (e.args)

结果: 1、因为不存在 writer 表( SQL 第三条语句),所以出现错误:Error 1146: Table ‘test.writer’ doesn’t exist 2、出现错误,出发异常处理, 3 条语句的前两条会自动变成了没有执行,结果不变 3、如果本代码放到一个 MyISAM 引擎表,前两句会执行,第三句不会;如果是 INNDB 引擎,则都不会执行。

python rowcount(如何用python最快的获取大文件的最后几行)

本文编辑:admin

本文相关文章:


python rowcount(python怎么处理mysql dmp文件)

python rowcount(python怎么处理mysql dmp文件)

本文目录python怎么处理mysql dmp文件如何用python操作数据库表如何使用python连接数据库,插入并查询数据如何用python最快的获取大文件的最后几行python怎么处理mysql dmp文件在Windows平台上安装m

2024年6月25日 13:07

更多文章:


mvvm原理面试(Web前端要掌握哪些技能,零基础小白能学前端吗)

mvvm原理面试(Web前端要掌握哪些技能,零基础小白能学前端吗)

本文目录Web前端要掌握哪些技能,零基础小白能学前端吗现在的前端工程师面试都问一些什么问题面试前端岗位,面试官会问哪些问题该如何准备面试后端岗位,有哪些面试官会问的问题该如何准备如果一个人有交社恐惧症,该怎么去面试前端框架更新迭代这么快,如

2024年7月19日 18:13

显示屏html模式转换(三星711n液晶显示器在开机后总自动转换模式怎么办)

显示屏html模式转换(三星711n液晶显示器在开机后总自动转换模式怎么办)

本文目录三星711n液晶显示器在开机后总自动转换模式怎么办如何把整个显示器,RGB调成cmyk色彩显示器双接口怎么切换HTMl 我做出来的网页在铁屏幕上显示是正常的.可是显示屏小的电脑上它就变形.或者把浏览器窗口减少它也会vs2010网站怎

2024年6月21日 13:11

二维码在线扫描(电脑怎么扫描二维码上网)

二维码在线扫描(电脑怎么扫描二维码上网)

本文目录电脑怎么扫描二维码上网怎么找到扫码在线图片电脑怎么扫描二维码电脑上怎么扫二维码什么条码扫描枪好用电脑怎么扫描二维码上网电脑怎么扫描二维码上网?电脑是我们生活中常用到的一款上网工具,那么电脑怎样扫描二维码呢,相信大家对这个问题很感兴趣

2024年7月23日 18:13

c++scanf是什么意思(scanf在c++中怎么用啊)

c++scanf是什么意思(scanf在c++中怎么用啊)

本文目录scanf在c++中怎么用啊scanf函数有什么用c/c++ 语言中cin与scanf有什么不同scanf(“%f“,&a)在c++中是什么意思c++中“scanf(“%2d%*2s%2d“, &x, &y);”是什么意思c++中s

2024年6月20日 13:33

fragrancenet中文官网(f网买错了怎么退)

fragrancenet中文官网(f网买错了怎么退)

各位老铁们,大家好,今天由我来为大家分享fragrancenet中文官网,以及f网买错了怎么退的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!本文目录f网买

2024年7月24日 00:18

java和python哪个简单(JAVA还是PYTHON学起来简单)

java和python哪个简单(JAVA还是PYTHON学起来简单)

这篇文章给大家聊聊关于java和python哪个简单,以及JAVA还是PYTHON学起来简单对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。本文目录JAVA还是PYTHON学起来简单python比java简单吗是不是python学习起

2024年10月6日 12:25

冷淡熊的歇后语有哪些?冷淡熊是谁

冷淡熊的歇后语有哪些?冷淡熊是谁

这篇文章给大家聊聊关于冷淡熊,以及冷淡熊的歇后语有哪些对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。本文目录冷淡熊的歇后语有哪些冷淡熊是谁茶酱和冷淡熊什么关系冷淡熊的配音怎么做的雪山山庄冷淡熊第几集冷淡熊几个人冷淡熊配音是几个人小煤

2024年8月10日 05:31

公司网站设计价格(公司想做一个网站,一般需要花多少钱)

公司网站设计价格(公司想做一个网站,一般需要花多少钱)

本文目录公司想做一个网站,一般需要花多少钱公司网站建设多少费用公司网站建设多少钱公司建设一个网站需要多少钱公司想做一个网站,一般需要花多少钱具体看要求,大部分钱都花在美工上面了,美工设计的越美观,当然也更费时间和费用了,企业网站一般在2k-

2024年7月15日 08:19

on purpose造句(用英语单词造句)

on purpose造句(用英语单词造句)

本文目录用英语单词造句英语单词造句、on purpose(故意) 用以上短语造句并翻译,谢谢用grown造句英语词组造句急!!!用英语单词造句1.My grandpa went through the second world war.2.

2024年6月28日 08:32

access数据库程序设计中vba的自动运行宏(请教懂vba的师傅,如何在编辑栏中输入某个字段,就触发表格自动运行某个宏不用按钮那种)

access数据库程序设计中vba的自动运行宏(请教懂vba的师傅,如何在编辑栏中输入某个字段,就触发表格自动运行某个宏不用按钮那种)

本文目录请教懂vba的师傅,如何在编辑栏中输入某个字段,就触发表格自动运行某个宏不用按钮那种access中vba运行程序还要加载宏access怎样用宏调用VBA请问excel vba 某个单元格区域变动,如何自动运行宏如何在启用excel时

2024年7月6日 12:38

巴菲特还在亏 三季度亏损26亿美元(巴菲特第三季亏损26亿美元:仍在减持比亚迪,他究竟做错了什么)

巴菲特还在亏 三季度亏损26亿美元(巴菲特第三季亏损26亿美元:仍在减持比亚迪,他究竟做错了什么)

这篇文章给大家聊聊关于巴菲特还在亏 三季度亏损26亿美元,以及巴菲特第三季亏损26亿美元:仍在减持比亚迪,他究竟做错了什么对应的知识点,希望对各位有所帮助,不要忘了收藏本站哦。本文目录巴菲特第三季亏损26亿美元:仍在减持比亚迪,他究竟做错了

2024年8月25日 15:45

怎样设置返回键在右边(手机返回键怎么调到右边)

怎样设置返回键在右边(手机返回键怎么调到右边)

本文目录手机返回键怎么调到右边安卓手机返回键怎么设置方法华为手机右下角返回键怎么设置华为nova3e返回键怎么换到右边oppo手机怎么设置返回键在右边华为返回键怎么调整到右边摩托罗拉手机返回键怎么设置在右边手机返回键怎么设置左右,oppo手

2024年7月1日 22:40

sqlite数据库管理器(sqlite数据库有啥用数据库是干啥的)

sqlite数据库管理器(sqlite数据库有啥用数据库是干啥的)

本文目录sqlite数据库有啥用数据库是干啥的如何设置sqlitesqlite 数据库管理工具 哪个好怎么使用SQLiteStudio来管理Sqlite数据库SQLite数据库管理工具 SQLPro for SQLite for Mac破解

2024年6月11日 04:35

数据加载失败3(welink数据加载失败)

数据加载失败3(welink数据加载失败)

大家好,今天小编来为大家解答以下的问题,关于数据加载失败3,welink数据加载失败这个很多人还不知道,现在让我们一起来看看吧!本文目录welink数据加载失败OPPO软件商店提示数据加载失败怎么办welink数据加载失败welink数据加

2024年7月22日 02:35

伦勃朗作品犹太新娘(中外美史所有著名画家及其作品 急急急 16号之前回答)

伦勃朗作品犹太新娘(中外美史所有著名画家及其作品 急急急 16号之前回答)

“伦勃朗作品犹太新娘”相关信息最新大全有哪些,这是大家都非常关心的,接下来就一起看看伦勃朗作品犹太新娘(中外美史所有著名画家及其作品 急急急 16号之前回答)!本文目录中外美史所有著名画家及其作品 急急急 16号之前回答伦勃朗的犹太新娘属于

2024年10月19日 05:01

css如何让div滑动显现(css3如何 设置一个div出现滚动条,并设置 样式)

css如何让div滑动显现(css3如何 设置一个div出现滚动条,并设置 样式)

本文目录css3如何 设置一个div出现滚动条,并设置 样式css怎么写 div 显示横向滚动条如何让div的滚动条在上下左右都出现css3里怎样使div从左(无)到右(有)滑入页面怎么样在div+css中设置一个div的框并出现滚动条网页

2024年7月13日 11:26

properties数学(.properties文件怎么查询是否有相同name -java语言)

properties数学(.properties文件怎么查询是否有相同name -java语言)

各位老铁们,大家好,今天由我来为大家分享properties数学,以及.properties文件怎么查询是否有相同name -java语言的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,

2024年10月12日 19:55

assignfile(Delphi7.0里面常用到的函数,及属性,事件有哪些)

assignfile(Delphi7.0里面常用到的函数,及属性,事件有哪些)

本文目录Delphi7.0里面常用到的函数,及属性,事件有哪些Delphi7.0里面常用到的函数,及属性,事件有哪些abort 函数 引起放弃的意外处理addexitproc 函数 将一过程添加到运行时库的结束过程表中addr 函数 返回指

2024年6月26日 02:42

bootstrap复杂表格(bootstrap table轻松实现数据表格)

bootstrap复杂表格(bootstrap table轻松实现数据表格)

大家好,如果您还对bootstrap复杂表格不太了解,没有关系,今天就由本站为大家分享bootstrap复杂表格的知识,包括bootstrap table轻松实现数据表格的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!本文

2024年10月22日 10:45

关系数据库的定义(关系数据库是什么)

关系数据库的定义(关系数据库是什么)

各位老铁们,大家好,今天由我来为大家分享关系数据库的定义,以及关系数据库是什么的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!本文目录关系数据库是什么什么是

2024年7月13日 00:50

近期文章

本站热文

iphone vpn设置(ios设置vpn快捷开关)
2024-07-22 15:01:12 浏览:2342
windows12正式版下载(操作系统Windows Server 2012 R2,在哪能下载到,公司用的)
2024-07-20 17:26:53 浏览:1736
client mfc application未响应(每次进cf就提示client MFC Application未响应该怎么办啊!急急急)
2024-07-20 11:15:58 浏览:1168
java安装教程(win10如何安装JAVA)
2024-07-19 19:55:49 浏览:1164
标签列表

热门搜索