list.append()एक सूची के अंत में जोड़ने के लिए स्पष्ट विकल्प है। यहां लापता के लिए एक उचित स्पष्टीकरण है list.prepend()। यह मानते हुए कि मेरी सूची छोटी है और प्रदर्शन की चिंताएं नगण्य हैं, है
list.insert(0, x)
या
list[0:0] = [x]
मुहावरेदार?
list.append()एक सूची के अंत में जोड़ने के लिए स्पष्ट विकल्प है। यहां लापता के लिए एक उचित स्पष्टीकरण है list.prepend()। यह मानते हुए कि मेरी सूची छोटी है और प्रदर्शन की चिंताएं नगण्य हैं, है
list.insert(0, x)
या
list[0:0] = [x]
मुहावरेदार?
जवाबों:
s.insert(0, x)प्रपत्र सबसे आम है।
जब भी आप इसे देखते हैं, यह एक सूची के बजाय एक संग्रह का उपयोग करने पर विचार करने का समय हो सकता है ।
यदि आप कार्यात्मक तरीके से जा सकते हैं, तो निम्नलिखित बहुत स्पष्ट है
new_list = [x] + your_list
बेशक, आपने इसमें सम्मिलित नहीं xकिया है your_list, बल्कि आपने इसके लिए एक नई सूची बनाई xहै।
एक छोटी अजगर सूची में शामिल होने के लिए मुहावरेदार वाक्यविन्यास क्या है?
आप आमतौर पर पाइथन की सूची में दोहराव नहीं चाहते हैं।
यदि यह छोटा है , और आप इसे बहुत अधिक नहीं कर रहे हैं ... तो ठीक है।
list.insertlist.insertइस तरह से इस्तेमाल किया जा सकता।
list.insert(0, x)
लेकिन यह अक्षम्य है, क्योंकि पायथन में, एक व्यूअर listका एक सरणी है, और पायथन को अब सूची में प्रत्येक पॉइंटर को लेना चाहिए और पहले स्लॉट में अपनी ऑब्जेक्ट में पॉइंटर डालने के लिए इसे एक से नीचे ले जाना चाहिए, इसलिए यह वास्तव में केवल कुशल है छोटी सूचियों के लिए, जैसा कि आप पूछते हैं।
यहां CPython स्रोत से एक स्निपेट दिया गया है जहां इसे लागू किया गया है - और जैसा कि आप देख सकते हैं, हम सरणी के अंत में शुरू करते हैं और हर प्रविष्टि के लिए एक-एक करके सब कुछ नीचे ले जाते हैं:
for (i = n; --i >= where; )
items[i+1] = items[i];
यदि आप एक कंटेनर / सूची चाहते हैं, जो पहले से मौजूद तत्वों में कुशल हो, तो आप एक लिंक की गई सूची चाहते हैं। पायथन की एक दोहरी लिंक वाली सूची है, जो शुरुआत और अंत में जल्दी से सम्मिलित कर सकता है - इसे ए कहा जाता है deque।
deque.appendleftA के collections.dequeपास सूची के कई तरीके हैं। list.sortएक अपवाद है, dequeनिश्चित रूप से पूरी तरह से Liskov के लिए स्थानापन्न नहीं है list।
>>> set(dir(list)) - set(dir(deque))
{'sort'}
dequeयह भी एक है appendleftविधि (और साथ ही popleft)। dequeएक डबल समाप्त हो गया है और एक कतार दोगुना से जुड़े सूची है - कोई बात नहीं की लंबाई, यह हमेशा preprend कुछ करने के लिए समय की एक ही राशि लेता है। सूचियों के लिए बड़े O संकेतन में, O (1) बनाम O (n) समय। यहाँ उपयोग है:
>>> import collections
>>> d = collections.deque('1234')
>>> d
deque(['1', '2', '3', '4'])
>>> d.appendleft('0')
>>> d
deque(['0', '1', '2', '3', '4'])
deque.extendleftइसके अलावा प्रासंगिक deque की extendleftविधि है, जो इसमें पूर्ववर्ती है :
>>> from collections import deque
>>> d2 = deque('def')
>>> d2.extendleft('cba')
>>> d2
deque(['a', 'b', 'c', 'd', 'e', 'f'])
ध्यान दें कि प्रत्येक तत्व को एक समय में एक पूर्व निर्धारित किया जाएगा, इस प्रकार उनके आदेश को प्रभावी ढंग से उलट दिया जाएगा।
listबनाम का प्रदर्शनdequeपहले हम कुछ पुनरावृत्तियों के साथ सेटअप करते हैं:
import timeit
from collections import deque
def list_insert_0():
l = []
for i in range(20):
l.insert(0, i)
def list_slice_insert():
l = []
for i in range(20):
l[:0] = [i] # semantically same as list.insert(0, i)
def list_add():
l = []
for i in range(20):
l = [i] + l # caveat: new list each time
def deque_appendleft():
d = deque()
for i in range(20):
d.appendleft(i) # semantically same as list.insert(0, i)
def deque_extendleft():
d = deque()
d.extendleft(range(20)) # semantically same as deque_appendleft above
और प्रदर्शन:
>>> min(timeit.repeat(list_insert_0))
2.8267281929729506
>>> min(timeit.repeat(list_slice_insert))
2.5210217320127413
>>> min(timeit.repeat(list_add))
2.0641671380144544
>>> min(timeit.repeat(deque_appendleft))
1.5863927800091915
>>> min(timeit.repeat(deque_extendleft))
0.5352169770048931
छल बहुत तेज है। जैसे-जैसे सूचियाँ लम्बी होंगी, मैं एक अच्छे प्रदर्शन की उम्मीद करूँगा। यदि आप deque का उपयोग कर सकते हैं, extendleftतो संभवतः आपको इस तरह का सर्वश्रेष्ठ प्रदर्शन मिलेगा।
अगर किसी को मेरी तरह यह सवाल लगता है, तो यहां प्रस्तावित विधियों के प्रदर्शन परीक्षण हैं:
Python 2.7.8
In [1]: %timeit ([1]*1000000).insert(0, 0)
100 loops, best of 3: 4.62 ms per loop
In [2]: %timeit ([1]*1000000)[0:0] = [0]
100 loops, best of 3: 4.55 ms per loop
In [3]: %timeit [0] + [1]*1000000
100 loops, best of 3: 8.04 ms per loop
जैसा कि आप देख सकते हैं, insertऔर स्लाइस असाइनमेंट स्पष्ट जोड़ने की तुलना में लगभग दोगुना है और परिणामों में बहुत करीब हैं। जैसा कि रेमंड हेटिंगर ने उल्लेख किया है, insertवह अधिक सामान्य विकल्प है और मैं, व्यक्तिगत रूप से इस तरह से सूची को प्रस्तुत करना पसंद करता हूं।
.insertऔर जगह में[0:0] = [0] काम करते हैं , फिर भी उन्हें पूरे बफर को फिर से आवंटित करना होगा।