色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:101日期: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函數是干什么的,看起來像是返回一段字符串dbcur怎么用來調用的呢,上面說dbcur應該重寫,在子類中重寫嗎,然后怎么調用啊

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

問題解答

回答1:

escape 是給string添加``符號。比如你創建的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這個函數拋出未實現這個異常,目的是為了充當接口,由子類去實現。Python里面沒有接口這個概念,所以定義接口時,可以采用這種方式。DbBase只付責構建sql語句,具體使用何種數據庫由子類實現,好處是可以適配不同的數據庫。

源碼:

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()

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 美女扒开双腿让男人桶 | 精品一区二区三区视频在线观看 | 欧美国产大片 | 一级一片一_级一片一 | 久久精品久久久 | 12345国产精品高清在线 | 成人免费视频网 | 亚洲欧美专区精品久久 | 久久久久亚洲视频 | 欧美日本免费观看αv片 | 亚洲理论视频 | 日本精品视频一区二区三区 | 岛国搬运工最新网地址 | 亚洲男人的天堂视频 | 亚洲精品社区 | 国产a∨一区二区三区香蕉小说 | 一级做a爰片久久毛片看看 一级做a爰片久久毛片鸭王 | 成年人免费黄色 | 日韩在线视频线视频免费网站 | 国产精品永久免费视频观看 | 欧美精品国产精品 | 免费岛国小视频在线观看 | 久久成人免费观看草草影院 | 99国产精品视频免费观看 | 成年男人午夜片免费观看 | 一区精品麻豆经典 | 高清偷自拍第1页 | 欧美一级在线视频 | 国产一区二区三区视频在线观看 | 综合 欧美 亚洲日本 | 99re热视频| 天堂mv亚洲mv在线播放9蜜 | 99久久久精品免费观看国产 | 久久免费视频网 | 久久久久久88色愉愉 | 看性过程三级视频在线观看 | 日韩一级一欧美一级国产 | 国产福利三区 | 欧美白人和黑人xxxx猛交视频 | 怡红院成人在线 | 美美女高清毛片视频免费观看 |