成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

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

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

瀏覽:109日期: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 編程
相關文章:
主站蜘蛛池模板: 黄色国产在线观看 | 成人国产欧美精品一区二区 | 久久99精品综合国产首页 | 亚洲一区二区三区免费视频 | 成年女人免费看 | 亚洲国产午夜看片 | 国产精品免费观看视频播放 | 国产精品爽爽va在线观看无码 | 日韩美女在线看免费观看 | 美国一级毛片∞ | 国产精品无圣光一区二区 | 亚洲精品视 | 视频在线二区 | 国产高清精品自在线看 | 亚洲欧美精品 | 国产免费爽爽视频免费可以看 | 日韩在线视频免费 | 国产精品亚洲专一区二区三区 | 欧美激情欧美狂野欧美精品免费 | 欧美国产大片 | 免费观看一级特黄欧美大片 | 99久久国语露脸精品对白 | 一级特一级特色生活片 | 色偷偷成人 | 欧美成年黄网站色视频 | 亚洲精品字幕一区二区三区 | 久久亚洲精品中文字幕亚瑟 | 国产成人亚洲日本精品 | 一级特级欧美aaaaa毛片 | 欧美成人资源 | 欧美成人免费 | 一级做a爱过程免费视频时看 | 亚洲视频在线一区 | 国产区香蕉精品系列在线观看不卡 | 在线看国产视频 | 黄频免费影院 | 成人在线视频免费看 | 国产一级毛片国产 | 亚洲 成人 欧美 自拍 | 国产日韩精品一区二区 | 99久久成人国产精品免费 |