亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

瀏覽:79日期: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 編程
相關文章:
主站蜘蛛池模板: 日本r级在线中文在线播放 日本tv欧美tv天堂 | 嫩草视频在线观看免费 | 一级毛片在线免费视频 | 我们不能是朋友未删减版在线看 | 日韩激情淫片免费看 | 亚洲国产第一区二区香蕉日日 | 免费视频91 | 国产色视频一区 | 黄色免费高清视频 | 欧美成人伊人久久综合网 | 亚洲精品一区二区综合 | 香蕉国产 | 黄色片视频在线免费观看 | 日本一级特黄aa大片在线观看 | 亚洲综合欧美色综合小说 | 26uuu在线| 中国女人真人一级毛片 | 长腿美女校花宿舍嗷嗷嗷大叫 | 自拍偷拍视频在线观看 | 五月婷婷精品 | 亚洲第一成年人网站 | 成人精品区 | 国产精品免费看久久久久 | 成人午夜毛片 | 九九亚洲精品自拍 | 亚洲国产精品毛片∧v卡在线 | 99久久免费中文字幕精品 | 久久久综合视频 | 色婷婷在线观看视频 | 在线免费观看黄色小视频 | 特黄特黄特色大片免费观看 | 日韩在线观看中文字幕 | 成人夜夜嗨 | 国产精品久久久久久久久免费观看 | 国产一区二区三区四区偷看 | 精品国产第一国产综合精品gif | 亚洲欧美综合国产精品一区 | 多男一女一级淫片免费播放口 | 成人在线观看国产 | 1024人成网站色| 免费激情网 |