একটি উপায় আছে রূপান্তর করতে হয় true
ধরনের unicode
1 এবং false
টাইপ unicode
(পাইথন মধ্যে) 0 কিভাবে?
উদাহরণ স্বরূপ: x == 'true' and type(x) == unicode
আমি চাই x = 1
PS: আমি ব্যবহার করতে চাই না if
- else
।
একটি উপায় আছে রূপান্তর করতে হয় true
ধরনের unicode
1 এবং false
টাইপ unicode
(পাইথন মধ্যে) 0 কিভাবে?
উদাহরণ স্বরূপ: x == 'true' and type(x) == unicode
আমি চাই x = 1
PS: আমি ব্যবহার করতে চাই না if
- else
।
উত্তর:
int()
বুলিয়ান পরীক্ষায় ব্যবহার করুন:
x = int(x == 'true')
int()
বুলেয়ানকে 1
বা তে পরিণত করে 0
। নোট করুন যে কোনও মান সমান নয়'true'
তার ফলস্বরূপ হবে 0
।
str
।
u'true' == 'true'
এ ফাংশনটি ইনপুট টাইপ থেকে [ str
এবং এর মধ্যে unicode
] থেকে নির্বিচারে সঠিকভাবে আচরণ করে ।
u'true' == 'true'
এবং ব্যবহারের ক্ষেত্রে কী তা আমরা জানি না। তারা পরিস্থিতি যেখানে একটি ভিন্ন আচরণ চান type(x) != unicode
।
arrayvalue == 'true'
তুলনা থেকে আপনি কী আশা করেন তা নিশ্চিত নই , আমি এখানে যে উত্তরটি উত্তর দিয়েছি তা একটি স্ট্রিং (ইউনিকোড) মানের সাথে নির্দিষ্ট।
যদি B
বুলিয়ান অ্যারে হয় তবে লিখুন
B = B*1
(একটি বিট কোড গল্ফ।)
numpy.multiply(B,1)
কাজ ব্যবহার করে।
B=map(int,B)
কার্যক্ষম ফলাফল দিয়েছে তখন আমার জন্য পাইথন ৩-এ মানচিত্রের মানচিত্র ফিরিয়ে দিয়েছে।
আপনার সমস্যার আরও একটি সমাধান এখানে দেওয়া হল:
def to_bool(s):
return 1 - sum(map(ord, s)) % 2
# return 1 - sum(s.encode('ascii')) % 2 # Alternative for Python 3
এটি কাজ করে কারণ ASCII কোড এর সমষ্টি 'true'
হল 448
, যা এমনকি, যখন এর ASCII কোড এর সমষ্টি 'false'
হল 523
যা বিজোড় হয়।
এই সমাধানটি সম্পর্কে মজার বিষয় হ'ল এর ফলাফলটি বেশ এলোমেলো হয় যদি ইনপুটটি এক বা এক না হয় । অর্ধেক সময় এটি ফিরে আসবে , এবং বাকি অর্ধেক । ইনপুটটি ASCII না হলে এই রূপটি ব্যবহার করে এনকোডিং ত্রুটি বাড়বে (এভাবে আচরণের অপরিজ্ঞাত-নেস বাড়ানো হবে)।'true'
'false'
0
1
encode
গুরুতরভাবে, আমি বিশ্বাস করি সর্বাধিক পঠনযোগ্য এবং দ্রুত , সমাধানটি হ'ল if
:
def to_bool(s):
return 1 if s == 'true' else 0
কিছু মাইক্রোব্যাঙ্কমার্ক দেখুন:
In [14]: def most_readable(s):
...: return 1 if s == 'true' else 0
In [15]: def int_cast(s):
...: return int(s == 'true')
In [16]: def str2bool(s):
...: try:
...: return ['false', 'true'].index(s)
...: except (ValueError, AttributeError):
...: raise ValueError()
In [17]: def str2bool2(s):
...: try:
...: return ('false', 'true').index(s)
...: except (ValueError, AttributeError):
...: raise ValueError()
In [18]: def to_bool(s):
...: return 1 - sum(s.encode('ascii')) % 2
In [19]: %timeit most_readable('true')
10000000 loops, best of 3: 112 ns per loop
In [20]: %timeit most_readable('false')
10000000 loops, best of 3: 109 ns per loop
In [21]: %timeit int_cast('true')
1000000 loops, best of 3: 259 ns per loop
In [22]: %timeit int_cast('false')
1000000 loops, best of 3: 262 ns per loop
In [23]: %timeit str2bool('true')
1000000 loops, best of 3: 343 ns per loop
In [24]: %timeit str2bool('false')
1000000 loops, best of 3: 325 ns per loop
In [25]: %timeit str2bool2('true')
1000000 loops, best of 3: 295 ns per loop
In [26]: %timeit str2bool2('false')
1000000 loops, best of 3: 277 ns per loop
In [27]: %timeit to_bool('true')
1000000 loops, best of 3: 607 ns per loop
In [28]: %timeit to_bool('false')
1000000 loops, best of 3: 612 ns per loop
লক্ষ্য করুন কিভাবে if
সমাধান অন্তত 2.5x বার দ্রুততর তুলনায় সব অন্যান্য সমাধান। এটা আছে না জানার জন্য প্রয়োজন যেমন লাগাতে ব্যবহার এড়াতে if
ছাড়া এই বাড়ির কাজ কিছু আছে (যে ক্ষেত্রে আপনি প্রথম স্থানে এই জিজ্ঞাসা করা উচিত নয়) গুলি।
আপনার যদি স্ট্রিং থেকে সাধারণ উদ্দেশ্য রূপান্তর প্রয়োজন যা প্রতি সেউকুল নয়, আপনার নীচের চিত্রিতের মতো একটি রুটিন লিখতে হবে। হাঁসের টাইপিংয়ের স্পিরিটের সাথে তাল মিলিয়ে, আমি চুপচাপ ত্রুটিটি পাস করি নি তবে বর্তমান পরিস্থিতির জন্য এটি উপযুক্ত হিসাবে রূপান্তর করেছি।
>>> def str2bool(st):
try:
return ['false', 'true'].index(st.lower())
except (ValueError, AttributeError):
raise ValueError('no Valid Conversion Possible')
>>> str2bool('garbaze')
Traceback (most recent call last):
File "<pyshell#106>", line 1, in <module>
str2bool('garbaze')
File "<pyshell#105>", line 5, in str2bool
raise TypeError('no Valid COnversion Possible')
TypeError: no Valid Conversion Possible
>>> str2bool('false')
0
>>> str2bool('True')
1
TypeError
? যদি স্ট্রিংটিতে না থাকে 'true'
বা 'false'
এটিতে একটি মান ত্রুটি থাকে। যদি ইনপুটটি স্ট্রিং না হয় তবে আপনি তার AttributeError
পরিবর্তে (99.99% বার) পাচ্ছেন , অতএব এটি এটির ValueError
জন্য এটি পুনরায় বাছাই করা অযথা TypeError
।
index
এট্রিবিউটআরারের উত্থানের উদাহরণ দিতে পারেন ?
return ['false', 'true'].index(s) except (ValueError, AttributeError)
।
lower()
কলটি সরিয়ে ফেলার সিদ্ধান্ত নিয়েছি কারণ এটি কেবলমাত্র এই অতিরিক্ত গণনা করেছিল এবং এটি মাইক্রো-বেঞ্চমার্কে অন্তর্ভুক্ত করা সঠিক হবে না। অবশ্যই try...except
কিছুটা সময় নেবেন অবশ্যই , তবে কোনও ব্যতিক্রম না বাড়ানো থাকলে ( 20ns
কম বা এর মতো ) পার্থক্যটি সামান্য ।
শুধুমাত্র এটির সাথে:
const a = true; const b = মিথ্যা;
কনসোল.লগ (+ এ); // 1 কনসোল.লগ (+ বি); // 0