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

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

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

瀏覽:112日期: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 編程
相關文章:
主站蜘蛛池模板: 夜间福利视频 | 欧美在线亚洲 | 日韩精品久久久 | 五月婷婷影院 | 97精品视频 | 欧美黑人一区二区三区 | 夜夜嗨av一区二区三区 | 好吊视频一区二区三区四区 | 国产精品一区在线播放 | 亚洲啪啪网| 久久少妇| 五月天婷婷网站 | 综合导航 | 国产精品一区久久 | 欧美日韩激情 | 自拍偷拍一区二区三区 | 福利三区 | 日本成人免费 | 91精品国产成人观看 | 免费的av| 视频一区在线播放 | 69久久久| 香蕉视频一直看一直爽 | 亚洲黄色av | 欧美日韩一区二区三区四区 | 亚洲成人免费在线观看 | 天堂中文av | 日韩黄色片 | 成年人黄色片 | 久久99热这里只频精品6学生 | 狠狠艹狠狠干 | 亚洲欧美视频在线观看 | 小镇姑娘国语版在线观看免费 | 久久人人爱| 日韩中文视频 | 91亚洲国产成人久久精品网站 | 在线观看欧美日韩视频 | 日韩欧美黄色 | 亚洲最新网址 | www.少妇| 日本三级在线视频 |