python - मैं एक पायथन urandom को एक स्ट्रिंग में कैसे परिवर्तित कर सकता हूं?
string python-3.x (2)
आप बेस -64 एन्कोडिंग का उपयोग कर सकते हैं। इस मामले में:
a = os.urandom(64)
a.encode('base-64')
यह भी ध्यान रखें कि मैं decode
बजाय यहां encode
का उपयोग कर रहा हूं, क्योंकि decode
इसे यूनिकोड में निर्दिष्ट प्रारूप से लेने की कोशिश कर रहा है। तो आपके उदाहरण में, आप यादृच्छिक बाइट्स का इलाज कर रहे हैं जैसे कि वे एक वैध utf-8
स्ट्रिंग बनाते हैं, जो शायद ही कभी यादृच्छिक बाइट्स के मामले में होता है।
अगर मैं os.urandom (64) को कॉल करता हूं, तो मुझे 64 यादृच्छिक बाइट्स दिए जाते हैं। एक पायथन स्ट्रिंग में बाइट्स कन्वर्ट करने के संदर्भ में मैंने कोशिश की
a = os.urandom(64)
a.decode()
a.decode("utf-8")
लेकिन ट्रेसबैक त्रुटि यह बताती है कि बाइट्स utf-8 में नहीं हैं।
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
UnicodeDecodeError: 'utf-8' codec can't decode byte 0x8b in position 0: invalid start byte
बाइट्स के साथ
b'\x8bz\xaf$\xb6\x93q\xef\x94\x99$\x8c\x1eO\xeb\xed\x03O\xc6L%\xe70\xf9\xd8
\xa4\xac\x01\xe1\xb5\x0bM#\x19\xea+\x81\xdc\xcb\xed7O\xec\xf5\\}\x029\x122
\x8b\xbd\xa9\xca\xb2\x88\r+\x88\xf0\xeaE\x9c'
क्या इन बाइट्स को कुछ स्ट्रिंग प्रस्तुति में डीकोड करने के लिए एक पूर्णप्रवाह विधि है? मैं कई डेटाबेस इंजनों में संबंधित दस्तावेज़ों का ट्रैक रखने के लिए सुडो यादृच्छिक टोकन उत्पन्न कर रहा हूं।
आपके पास यादृच्छिक बाइट्स हैं; अगर मैं कभी स्ट्रिंग के लिए डीकोडेबल था तो मुझे आश्चर्य होगा।
यदि आपके पास यूनिकोड स्ट्रिंग है, तो लैटिन -1 से डीकोड करें:
a.decode('latin1')
क्योंकि यह संबंधित यूनिकोड कोड बिंदुओं पर एक-एक-एक करके बाइट्स को मानचित्र करता है।