国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

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

瀏覽:84日期: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 編程
相關文章:
主站蜘蛛池模板: 亚洲在线免费视频 | 特级黄色毛片视频 | 国产午夜精品理论片免费观看 | 亚洲成年人专区 | 日本xxxxx久色视频在线观看 | 免费看欧美毛片大片免费看 | 亚洲精品影院一区二区 | 欧美6699在线视频免费 | 萌白酱福利视频 | 欧美线在线精品观看视频 | 99久久免费视频在线观看 | 综合精品 | 18视频免费网址在线观看 | 日本欧美做爰全免费的视频 | 欧美f| 99视频在线免费观看 | 亚洲综合网在线 | 精品9e精品视频在线观看 | 国产乱子伦在线观看不卡 | 中国一级特黄视频 | 久久这里只有精品免费视频 | 天堂mv亚洲mv在线播放9蜜 | 国内自拍一区 | 亚洲一级特黄特黄的大片 | 欧美激情一级欧美精品 | 亚洲视频在线a视频 | 成人怡红院 | 成人在线播放视频 | 久久99国产乱子伦精品免费 | 怡红院免费全部视频在线视频 | 免费一级欧美大片久久网 | 国产亚洲女在线精品 | 国产特黄特色的大片观看免费视频 | 亚洲一级毛片免费看 | 一区二区三区中文字幕 | 欧美亚洲一区二区三区 | 亚洲欧美日本国产 | 久久国产高清 | 国产vs久久 | 国产主播福利片在线观看 | 成人在线观看网址 |