电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

Python字典鍵。“復雜”的

瀏覽:15日期:2022-08-07 10:05:53
如何解決Python字典鍵。“復雜”的?

首先,key in d.keys()保證為您提供與key in ddict相同的值d。

而且,in對dict或操作(從3.x中dict_keys調用)返回的對象的操作 不是 O(N),而是O(1)。keys() __

沒有真正的“優化”。只是使用哈希是在__contains__哈希表上實現的明顯方法,就像它是實現的明顯方法一樣__getitem__。

您可能會問這在哪里得到保證。

好吧,不是。映射類型將dict基本上定義為的哈希表實現collections.abc.Mapping。沒有什么可以阻止某人創建Mapping的哈希表實現的,但是仍然可以提供O(N)搜索。但是,要實現如此糟糕的實現將是額外的工作,那么為什么要這么做呢?

如果您確實需要自己證明它,則可以測試您關心的每個實現(使用探查器,或者通過將某種類型與自定義一起使用,__hash__并__eq__記錄調用,或者…),或者閱讀源代碼。

在2.x中,您不想調用keys,因為它會生成一個list密鑰,而不是一個KeysView。您可以使用iterkeys,但可能會生成迭代器或其他不是O(1)的東西。因此,只需將dict本身用作序列即可。

即使在3.x中,也不需要調用keys,因為沒有必要。迭代a dict,檢查其__contains__,并且通常將其視為序列 總是等同于對其鍵執行相同的操作,那么為什么要打擾呢?(當然,構建瑣碎的宏keyview并進行訪問將使您的運行時間增加幾納秒,并為程序增加一些擊鍵。)

(尚不清楚d.keys()/d.iterkeys()和d2.x中使用序列運算是否等效。除了性能問題外,它們在每個cpython,Jython,IronPython和PyPy實現中均 等效,但是似乎在任何地方都沒有說明。 3.x中的方式。這并不重要;只需使用key in d。)

在進行此操作時,請注意以下幾點:

if(dict[key] != None):

……將無法正常工作。如果key不在中dict,則將引發KeyError而不返回None。

另外,您永遠不要None使用==或進行檢查!=。經常使用is。

您可以使用try-或更簡單地說,執行do if dict.get(key, None) is notNone。但是同樣,沒有理由這樣做。此外,這將無法處理None完全有效的物品。在這種情況下,您需要執行sentinel = object(); ifdict.get(key, sentinel) is not sentinel:。

因此,正確的寫法是:

if key in d:

更普遍地說,這是不正確的:

我知道關鍵字“ in”通常為O(n)(因為這僅表示python遍歷整個列表并比較每個元素

in與大多數其他運算符一樣,該運算符僅是對__contains__方法的調用(或等效于內置的C / Java / .NET /RPython)。list通過迭代列表并比較每個元素來實現它;dict通過散列值并查找散列來實現它;blist.blist通過走B +Tree來實現它;因此,它可以是O(n),O(1),O(log n)或完全不同的東西。

解決方法

快速提問主要滿足我對這個話題的好奇心。

我正在編寫一些帶有SQlite數據庫后端的大型python程序,并且將來會處理大量記錄,因此,我需要盡可能地優化。

對于一些功能,我正在字典中搜索關鍵字。我一直在使用“ in”關鍵字進行原型設計,并計劃稍后返回并優化這些搜索,因為我知道“in”關鍵字通常為O(n)(因為這僅表示python遍歷整個列表并進行比較每個元素)。但是,由于pythondict基本上只是一個哈希映射,因此python解釋器足夠聰明來解釋:

if(key in dict.keys()): ...code...

至:

if(dict[key] != None): ...code...

它基本上是相同的操作,但頂部為O(n),底部為O(1)。

對我來說,在代碼中使用底部版本很容易,但是后來我很好奇并以為我會問。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 私人别墅家庭影院系统_家庭影院音响_家庭影院装修设计公司-邦牛影音 | 网站制作优化_网站SEO推广解决方案-无锡首宸信息科技公司 | 智成电子深圳tdk一级代理-提供TDK电容电感贴片蜂鸣器磁芯lambda电源代理经销,TDK代理商有哪些TDK一级代理商排名查询。-深圳tdk一级代理 | SDG吸附剂,SDG酸气吸附剂,干式酸性气体吸收剂生产厂家,超过20年生产使用经验。 - 富莱尔环保设备公司(原名天津市武清县环保设备厂) | 定制液氮罐_小型气相液氮罐_自增压液氮罐_班德液氮罐厂家 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 包装机_厂家_价格-山东包装机有限公司 | 成都租车_成都租车公司_成都租车网_众行宝 | 无锡装修装潢公司,口碑好的装饰装修公司-无锡索美装饰设计工程有限公司 | 安徽净化工程设计_无尘净化车间工程_合肥净化实验室_安徽创世环境科技有限公司 | 考勤系统_考勤管理系统_网络考勤软件_政企|集团|工厂复杂考勤工时统计排班管理系统_天时考勤 | 胜为光纤光缆_光纤跳线_单模尾纤_光纤收发器_ODF光纤配线架厂家直销_北京睿创胜为科技有限公司 - 北京睿创胜为科技有限公司 | 高中学习网-高考生信息学习必备平台 | 诺冠气动元件,诺冠电磁阀,海隆防爆阀,norgren气缸-山东锦隆自动化科技有限公司 | 冷却塔减速机器_冷却塔皮带箱维修厂家_凉水塔风机电机更换-广东康明冷却塔厂家 | 石家庄装修设计_室内家装设计_别墅装饰装修公司-石家庄金舍装饰官网 | 移动机器人产业联盟官网 | 实战IT培训机构_IT培训班选大学生IT技术培训中心_中公优就业 | 同学聚会纪念册制作_毕业相册制作-成都顺时针宣传画册设计公司 | 冲锋衣滑雪服厂家-冲锋衣定制工厂-滑雪服加工厂-广东睿牛户外(S-GERT) | TwistDx恒温扩增-RAA等温-Jackson抗体-默瑞(上海)生物科技有限公司 | 硫酸亚铁-聚合硫酸铁-除氟除磷剂-复合碳源-污水处理药剂厂家—长隆科技 | 酶联免疫分析仪-多管旋涡混合仪|混合器-莱普特科学仪器(北京)有限公司 | 一路商机网-品牌招商加盟优选平台-加盟店排行榜平台 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 北京京云律师事务所 | 绿萝净除甲醛|深圳除甲醛公司|测甲醛怎么收费|培训机构|电影院|办公室|车内|室内除甲醛案例|原理|方法|价格立马咨询 | 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 一体化污水处理设备_生活污水处理设备_全自动加药装置厂家-明基环保 | 高楼航空障碍灯厂家哪家好_航空障碍灯厂家_广州北斗星障碍灯有限公司 | 汽车水泵_汽车水泵厂家-瑞安市骏迪汽车配件有限公司 | 光栅尺厂家_数显表维修-苏州泽升精密机械 | 北京自然绿环境科技发展有限公司专业生产【洗车机_加油站洗车机-全自动洗车机】 | Honsberg流量计-Greisinger真空表-气压计-上海欧臻机电设备有限公司 | 招商帮-一站式网络营销服务|互联网整合营销|网络推广代运营|信息流推广|招商帮企业招商好帮手|搜索营销推广|短视视频营销推广 | 电伴热系统施工_仪表电伴热保温箱厂家_沃安电伴热管缆工业技术(济南)有限公司 | 振动台-振动试验台-振动冲击台-广东剑乔试验设备有限公司 | 导电银胶_LED封装导电银胶_半导体封装导电胶厂家-上海腾烁 | CCC验厂-家用电器|服务器CCC认证咨询-奥测世纪 | 27PR跨境电商导航 | 专注外贸跨境电商 | 电解抛光加工_不锈钢电解抛光_常州安谱金属制品有限公司 |