午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

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

問(wèn)題描述

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ù)是干什么的,看起來(lái)像是返回一段字符串dbcur怎么用來(lái)調(diào)用的呢,上面說(shuō)dbcur應(yīng)該重寫,在子類中重寫嗎,然后怎么調(diào)用啊

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

問(wèn)題解答

回答1:

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

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

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

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

源碼:

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)文章:
主站蜘蛛池模板: 欧美黄色大片免费观看 | 国产成人精品毛片 | 国产jizz18女人高潮 | 91九色国产| 中国a一片一级一片 | 亚洲热在线观看 | 日本久久久久 | 手机在线看a | 黄色精品网站 | 在线免费av网站 | 五十路在线 | 韩日精品在线 | 黄色网免费看 | 一级片国产 | 成人看片免费 | 欧美一级爽aaaaa大片 | 久久精品视频免费看 | 成人资源在线 | 日本一区二区三区在线观看视频 | a在线视频 | 精品日本一区二区 | 深夜视频在线免费观看 | 黄色国产网站 | 国产成人在线免费观看 | 中文日韩字幕 | 日韩精品久久久久久久 | 精品成人在线 | 日韩av片在线免费观看 | 美腿丝袜av | 夜夜天天操 | 欧美中文字幕在线 | 免费看黄色一级视频 | 久久国产91 | 日韩av在线免费播放 | √资源天堂中文在线 | 亚洲精品日韩在线 | 亚洲天堂视频网 | 九一成人网 | 亚洲一区在线观看视频 | 黑人巨大精品欧美 | 亚洲精品免费播放 |