পাইথন পুনরায় পাঠকরা কি কোনও hasNextপদ্ধতি পেয়েছেন ?
পাইথন পুনরায় পাঠকরা কি কোনও hasNextপদ্ধতি পেয়েছেন ?
উত্তর:
না, এমন কোনও পদ্ধতি নেই। পুনরাবৃত্তির শেষটি ব্যতিক্রম দ্বারা নির্দেশিত হয়। ডকুমেন্টেশন দেখুন ।
unnext()কল করার মাধ্যমে এটি উপস্থিত রয়েছে কিনা তা যাচাই করে নেওয়ার পরে যদি প্রথম উপাদানটিকে পিছনে রাখার কোনও পদ্ধতি ছিল তবে আমি চেষ্টা ধরার সমাধানটি গ্রহণ করব next()।
yieldনা)। এটি অবশ্যই কোনও অ্যাডাপ্টার লিখতে অসুবিধা নয় যা ফলাফল সংরক্ষণ করে next()এবং সরবরাহ করে has_next()এবং move_next()।
hasNext()পদ্ধতিটি প্রয়োগ করতে (উত্পাদন, ক্যাশে এবং সাফল্যে সত্য প্রত্যাবর্তন, বা ব্যর্থতায় মিথ্যা প্রত্যাবর্তনের জন্য) ব্যবহার করা যেতে পারে । তারপরে hasNext()এবং উভয়ই next()একটি সাধারণ অন্তর্নিহিত getNext()পদ্ধতি এবং ক্যাশেড আইটেমের উপর নির্ভর করবে । আমি সত্যিই দেখতে পাই না কেন next()স্ট্যান্ডার্ড লাইব্রেরিতে না থাকা উচিত যদি এটি সরবরাহ করে এমন একটি অ্যাডাপ্টার কার্যকর করতে এত সহজ হয়।
next()এবং hasNext()পদ্ধতিকে প্রভাবিত করে )। সুতরাং হ্যাঁ, next()এবং hasNext()স্ট্রিমের বিষয়বস্তুটি স্ক্যান করার সময় উপাদানগুলি কখন পড়ার উপর নির্ভর করে trick
StopIterationব্যবহার করে একটি বিকল্প আছে next(iterator, default_value)।
এক্সপামলের জন্য:
>>> a = iter('hi')
>>> print next(a, None)
h
>>> print next(a, None)
i
>>> print next(a, None)
None
সুতরাং আপনি Noneযদি ব্যতিক্রম উপায় না চান তবে আপনি পুনরাবৃত্তির শেষের জন্য বা অন্যান্য পূর্বনির্ধারিত মান সনাক্ত করতে পারেন ।
sentinel = object()এবং next(iterator, sentinel)এবং পরীক্ষা is।
unittest.mock.sentinelঅবজেক্টটি ব্যবহার করব যা আপনাকে স্পষ্ট করে লিখতে next(a, sentinel.END_OF_ITERATION)এবং তারপরেif next(...) == sentinel.END_OF_ITERATION
আপনি কি সত্যিই যদি প্রয়োজন একটি has-nextকার্যকারিতা (কারণ আপনি শুধু নিখুঁতভাবে জাভা একটি রেফারেন্স বাস্তবায়ন থেকে একটি অ্যালগরিদম নকলনবিসি করছি, বলুন বা কারণ আপনি একটি প্রোটোটাইপ যে লেখার হবে সহজে জাভা প্রতিলিপি করা এটি সমাপ্ত হলে প্রয়োজন), এটা করা খুবই সহজ এটি একটি সামান্য মোড়কের ক্লাসের সাথে গ্রহণ করুন। উদাহরণ স্বরূপ:
class hn_wrapper(object):
def __init__(self, it):
self.it = iter(it)
self._hasnext = None
def __iter__(self): return self
def next(self):
if self._hasnext:
result = self._thenext
else:
result = next(self.it)
self._hasnext = None
return result
def hasnext(self):
if self._hasnext is None:
try: self._thenext = next(self.it)
except StopIteration: self._hasnext = False
else: self._hasnext = True
return self._hasnext
এখন যেমন কিছু
x = hn_wrapper('ciao')
while x.hasnext(): print next(x)
নিঃসরণ করে
c
i
a
o
প্রয়োজনীয়.
মনে রাখবেন যে next(sel.it)বিল্ট-ইন হিসাবে ব্যবহারের জন্য পাইথন ২.6 বা তারও বেশি প্রয়োজন; যদি আপনি পাইথনের একটি পুরানো সংস্করণ ব্যবহার করেন তবে self.it.next()পরিবর্তে (এবং একইভাবে next(x)উদাহরণ ব্যবহারের জন্য) ব্যবহার করুন। [[আপনি সম্ভবত যুক্তিযুক্তভাবে এই নোটটি অপ্রয়োজনীয় হিসাবে ভাবতে পারেন, যেহেতু পাইথন ২.6 এখন প্রায় এক বছরেরও বেশি সময় ধরে চলেছে - তবে প্রায়শই আমি যখন সাড়াতে পাইথন ২.6 বৈশিষ্ট্য ব্যবহার করি না তখনই কিছু মন্তব্যকারী বা অন্যান্য মনে করেন যে দায়িত্বটি বাধ্যবাধকতা রয়েছে) তারা যে হয় 2.6 বৈশিষ্ট্য, এইভাবে আমি একবার ;-)]] এর জন্য এই ধরনের মন্তব্য আটকানোর চেষ্টা করছি
has_nextপদ্ধতির প্রয়োজন সবচেয়ে খারাপ কারণ । পাইথনের নকশায় বলা হয়েছে, filterকোনও অ্যারে প্রদত্ত প্রাকটিকের সাথে মিল রেখে কোনও উপাদান রয়েছে কিনা তা পরীক্ষা করে দেখতে অসম্ভব করে তোলে । পাইথন সম্প্রদায়ের অহংকার ও সংক্ষিপ্ততা বিস্ময়কর।
TypeError: iter() returned non-iterator
mapএবং anyতার পরিবর্তে filter, তবে আপনি SENTINEL = object(); next(filter(predicate, arr), SENTINEL) is not SENTINELএকটি ব্যবহার করতে বা ভুলে যেতে পারেন SENTINELএবং কেবল ব্যবহার করতে try: exceptএবং ধরতে পারেন StopIteration।
স্টপআইটারেশনের সমস্ত উল্লেখের পাশাপাশি পাইথন "ফর" লুপটি আপনি যা চান তা কেবলভাবে করে:
>>> it = iter("hello")
>>> for i in it:
... print i
...
h
e
l
l
o
যে কোনও পুনরাবৃত্তকারী অবজেক্ট থেকে __leight_hint __ () পদ্ধতিটি ব্যবহার করে দেখুন:
iter(...).__length_hint__() > 0
__init__এবং __main__? ইমো, আপনি এটিকে ন্যায্য প্রমাণ করার চেষ্টা করুন না কেন এটি কিছুটা গণ্ডগোল।
hasNextকিছুটা StopIterationব্যতিক্রম যেমন অনুবাদ করে :
>>> it = iter("hello")
>>> it.next()
'h'
>>> it.next()
'e'
>>> it.next()
'l'
>>> it.next()
'l'
>>> it.next()
'o'
>>> it.next()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
StopIteration
StopIterationদস্তাবেজ: http://docs.python.org/library/exception.html#exferences.ShopIterationনা। সর্বাধিক অনুরূপ ধারণাটি সম্ভবত একটি স্টপআইটিরেশন ব্যতিক্রম।
আমি বিশ্বাস করি অজগরটির ঠিক পাশেই রয়েছে () এবং ডক অনুসারে এটি একটি ব্যতিক্রম ছুঁড়েছে কারণ সেখানে আরও কিছু উপাদান নেই।
ব্যবহারের ক্ষেত্রে যা আমাকে এটি অনুসন্ধান করতে পরিচালিত করে তা নীচে রয়েছে
def setfrom(self,f):
"""Set from iterable f"""
fi = iter(f)
for i in range(self.n):
try:
x = next(fi)
except StopIteration:
fi = iter(f)
x = next(fi)
self.a[i] = x
যেখানে সংক্ষিপ্তসার () পাওয়া যায়, সেখানে কেউ করতে পারে
def setfrom(self,f):
"""Set from iterable f"""
fi = iter(f)
for i in range(self.n):
if not hasnext(fi):
fi = iter(f) # restart
self.a[i] = next(fi)
আমার কাছে যা পরিষ্কার। স্পষ্টতই আপনি ইউটিলিটি ক্লাসগুলি সংজ্ঞায়িত করে ইস্যুগুলি নিয়ে কাজ করতে পারেন, তবে তারপরে যা ঘটে তা হ'ল আপনার কুড়ি দিয়ে প্রতিটি বিশ-মতামত প্রায় সমতুল্য ওয়ার্কারআউন্ডের বিস্তার এবং আপনি যদি আলাদা ওয়ার্কআউন্ড ব্যবহার করে এমন কোডটি পুনরায় ব্যবহার করতে চান, তবে আপনাকে অবশ্যই আপনার একক অ্যাপ্লিকেশনটিতে একাধিক কাছের সমতুল্য রয়েছে, বা একই পদ্ধতির ব্যবহার করতে কোডটি পুনর্নির্মাণ এবং পুনর্লিখনের কাছাকাছি যান। 'একবার এটি করুন এবং ভালভাবে করুন' ম্যাক্সিমামটি খারাপভাবে ব্যর্থ হয়।
তদুপরি, পুনরুক্তিকারীর নিজেই কোনও ব্যতিক্রম বাড়াতে হবে কিনা তা চালানোর জন্য চালানোর জন্য একটি অভ্যন্তরীণ 'হেসেক্সট' চেক করা দরকার। এরপরে এই অভ্যন্তরীণ চেকটি গোপন করা হয়েছে যাতে এটি কোনও আইটেম পাওয়ার চেষ্টা করে, ব্যতিক্রমটি ধরতে এবং নিক্ষেপ করা হলে হ্যান্ডলারটি চালিয়ে পরীক্ষা করার প্রয়োজন হয়। এটি অপ্রয়োজনীয় লুকানো আইএমও।
প্রস্তাবিত উপায় হ'ল স্টপআইটিরেশন । টিউটোরিয়ালপয়েন্ট থেকে ফিবোনাকির উদাহরণ দেখুন
#!usr/bin/python3
import sys
def fibonacci(n): #generator function
a, b, counter = 0, 1, 0
while True:
if (counter > n):
return
yield a
a, b = b, a + b
counter += 1
f = fibonacci(5) #f is iterator object
while True:
try:
print (next(f), end=" ")
except StopIteration:
sys.exit()
আমি যেভাবে আমার সমস্যার সমাধান করেছি তা হ'ল এতক্ষণ অবজেক্টের সংখ্যার গণনা রাখা। আমি একটি উদাহরণ পদ্ধতিতে কল ব্যবহার করে একটি সেট পুনরাবৃত্তি করতে চেয়েছিলাম। যেহেতু আমি সেটটির দৈর্ঘ্য এবং এখন পর্যন্ত গণনা করা আইটেমগুলির সংখ্যা জানতাম, তাই কার্যকরভাবে আমার একটি hasNextপদ্ধতি ছিল ।
আমার কোডের একটি সাধারণ সংস্করণ:
class Iterator:
# s is a string, say
def __init__(self, s):
self.s = set(list(s))
self.done = False
self.iter = iter(s)
self.charCount = 0
def next(self):
if self.done:
return None
self.char = next(self.iter)
self.charCount += 1
self.done = (self.charCount < len(self.s))
return self.char
def hasMore(self):
return not self.done
অবশ্যই, উদাহরণটি একটি খেলনা, তবে আপনি ধারণাটি পান। জেনারেটর ইত্যাদির মতো পুনরাবৃত্তের দৈর্ঘ্য পাওয়ার কোনও উপায় না থাকলে এটি কাজ করবে না This