av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

pyspider - python這個類中的方法到底有什么用處啊

瀏覽:92日期:2022-08-27 10:12:02

問題描述

class BaseDB: ’’’ BaseDB dbcur should be overwirte ’’’ __tablename__ = None placeholder = ’%s’ maxlimit = -1 @staticmethod def escape(string):return ’`%s`’ % string @property def dbcur(self):raise NotImplementedError

escape函數(shù)是干什么的,看起來像是返回一段字符串dbcur怎么用來調(diào)用的呢,上面說dbcur應(yīng)該重寫,在子類中重寫嗎,然后怎么調(diào)用啊

pyspider代碼https://github.com/binux/pysp...

問題解答

回答1:

escape 是給string添加``符號。比如你創(chuàng)建的table或者column里有空白字符時。

create table `hello world tb` (`column name1` INT NOT NULL AUTO_INCREMENT PRIMARY KEY)

錯誤的查詢:select column name1 from hello world tb正確的查詢:select `column name1` from `hello world tb`

dbcur這個函數(shù)拋出未實(shí)現(xiàn)這個異常,目的是為了充當(dāng)接口,由子類去實(shí)現(xiàn)。Python里面沒有接口這個概念,所以定義接口時,可以采用這種方式。DbBase只付責(zé)構(gòu)建sql語句,具體使用何種數(shù)據(jù)庫由子類實(shí)現(xiàn),好處是可以適配不同的數(shù)據(jù)庫。

源碼:

if __name__ == '__main__': import sqlite3 class DB(BaseDB):__tablename__ = 'test'placeholder = '?'def __init__(self): self.conn = sqlite3.connect(':memory:') cursor = self.conn.cursor() cursor.execute(’’’CREATE TABLE `%s` (id INTEGER PRIMARY KEY AUTOINCREMENT, name, age)’’’% self.__tablename__ )@propertydef dbcur(self): return self.conn.cursor()

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 国产精品夜间视频香蕉 | 欧美激情久久久 | 狠狠操网站 | 午夜影院在线观看免费 | 美女视频黄的免费 | 午夜国产一级片 | 国产激情视频在线观看 | 亚洲91精品| 欧产日产国产精品国产 | 中文字幕乱码一区二区三区 | 一区二区三区精品在线视频 | 国产精品久久 | 日韩欧美在线观看视频网站 | 精品免费视频 | 亚洲日日夜夜 | 免费的网站www | 国产一区二区在线视频 | 一区二区三区视频 | 午夜视频网 | 久久伊 | 亚洲精品一二区 | 岛国一区| 中文字幕亚洲欧美 | 国产午夜精品久久久久 | 青青艹在线视频 | 一二区成人影院电影网 | 亚洲免费视频网址 | 欧美性乱 | 色播视频在线观看 | 天天综合网7799精品 | 欧美一区二区三区视频 | 99精品网 | 欧美日日 | 2019天天干天天操 | 久久伊人影院 | 欧美一区二区三区四区五区无卡码 | 一级a性色生活片久久毛片波多野 | 99re在线播放 | 国产专区免费 | 91色啪 | 97超碰站|