__Str__ සහ __repr__ අතර වෙනස?


Answers:


2747

ඇලෙක්ස් හොඳින් සාරාංශ කළ නමුත් පුදුමයට කරුණක් නම් එය ඉතා සංක්ෂිප්ත ය.

පළමුව, ඇලෙක්ස්ගේ ලිපියේ ප්‍රධාන කරුණු නැවත අවධාරණය කිරීමට මට ඉඩ දෙන්න :

  • පෙරනිමි ක්‍රියාත්මක කිරීම නිෂ් less ල ය (එසේ නොවන එකක් ගැන සිතීම දුෂ්කර ය, නමුත් ඔව්)
  • __repr__ ඉලක්කය නිසැක ය
  • __str__ ඉලක්කය කියවිය හැකි වීමයි
  • රුවනයකි ගේ __str__භාවිතා අඩංගු වස්තූන් '__repr__

පෙරනිමි ක්‍රියාත්මක කිරීම නිෂ් .ල ය

මෙය බොහෝ දුරට පුදුමයට කරුණක් වන්නේ පයිතන්ගේ පෙරනිමිති තරමක් ප්‍රයෝජනවත් වන බැවිනි. කෙසේ වෙතත්, මෙම අවස්ථාවේ දී, පෙරනිමියක් තිබීම __repr__පහත පරිදි ක්‍රියා කරයි:

return "%s(%r)" % (self.__class__, self.__dict__)

(උදාහරණයක් ලෙස, වස්තූන් එකිනෙක ගැන සඳහන් කරන්නේ නම් අනන්ත පුනරාවර්තනයකට පිවිසීමට පහසු නැත). ඉතින් පයිතන් එළියට එනවා. එක් පෙරනිමියක් සත්‍ය බව සලකන්න: __repr__අර්ථ දක්වා ඇත්නම් සහ __str__එසේ නොවේ නම්, වස්තුව හැසිරෙනු ඇත __str__=__repr__.

මෙයින් අදහස් කරන්නේ, සරල වචන වලින්: ඔබ ක්‍රියාත්මක කරන සෑම වස්තුවකටම පාහේ වස්තුව __repr__තේරුම් ගැනීමට භාවිතා කළ හැකි ක්‍රියාකාරීත්වයක් තිබිය යුතුය . ක්‍රියාත්මක __str__කිරීම අත්‍යවශ්‍ය නොවේ: ඔබට “ලස්සන මුද්‍රණ” ක්‍රියාකාරීත්වයක් අවශ්‍ය නම් එය කරන්න (උදාහරණයක් ලෙස වාර්තා උත්පාදකයක් භාවිතා කරයි).

පරමාර්ථය __repr__නිසැක ය

මට වහාම එළියට පැමිණ එය කියන්නට ඉඩ දෙන්න - මම නිදොස් කරන්නන් විශ්වාස නොකරමි. කිසිදු නිදොස් කිරීමක් භාවිතා කරන්නේ කෙසේදැයි මම නොදනිමි, කිසි විටෙකත් බැරෑරුම් ලෙස භාවිතා කර නැත. තව දුරටත්, නිදොස්කරණය කරන්නන්ගේ විශාල දෝෂය ඔවුන්ගේ මූලික ස්වභාවය බව මම විශ්වාස කරමි - මා විසින් නිදොස්කරණය කරන ලද බොහෝ අසාර්ථකත්වයන් බොහෝ කලකට පෙර, දුර .ත මන්දාකිනියක සිදුවිය. මෙයින් අදහස් කරන්නේ, ආගමික උද්යෝගයෙන්, දැව කැපීමේදී මා විශ්වාස කරන බවයි. ලොග් වීම යනු ඕනෑම හොඳ ගිනි හා අමතක වූ සේවාදායක පද්ධතියක ජීව රුධිරයයි. පයිතන් ලොග් වීම පහසු කරයි: සමහර විට ව්‍යාපෘති විශේෂිත ආවරණ සහිතව, ඔබට අවශ්‍ය වන්නේ අ

log(INFO, "I am in the weird function and a is", a, "and b is", b, "but I got a null C — using default", default_c)

නමුත් ඔබ කළ යුත්තේ අවසාන පියවරයි - ඔබ ක්‍රියාත්මක කරන සෑම වස්තුවකටම ප්‍රයෝජනවත් repr එකක් ඇති බවට වග බලා ගන්න, එබැවින් එවැනි කේතයක් ක්‍රියා කළ හැකිය. “එවාල්” කාරණය පැමිණෙන්නේ මේ නිසා ය: ඔබට ප්‍රමාණවත් තොරතුරු තිබේ නම් eval(repr(c))==c, එයින් අදහස් වන්නේ ඔබ දැනගත යුතු සියල්ල ඔබ දන්නා බවයි c. එය ප්‍රමාණවත් තරම් පහසු නම්, අවම වශයෙන් නොපැහැදිලි ආකාරයකින් එය කරන්න. එසේ නොවේ නම්, cකෙසේ හෝ ඔබට ප්‍රමාණවත් තොරතුරු ඇති බවට වග බලා ගන්න . මම සාමාන්‍යයෙන් එවාල් වැනි ආකෘතියක් භාවිතා කරමි : "MyClass(this=%r,that=%r)" % (self.this,self.that). ඔබට සැබවින්ම මයික්ලාස් සෑදිය හැකි බව හෝ ඒවා නිවැරදි ඉදිකිරීම් තර්ක යැයි එයින් අදහස් නොකෙරේ - නමුත් “මෙම අවස්ථාව ගැන ඔබ දැනගත යුතු සියල්ල මෙයයි” යන්න ප්‍රකාශ කිරීමට එය ප්‍රයෝජනවත් ආකාරයකි.

සටහන: මම %rඉහත භාවිතා කළෙමි , නැත %s. ක්‍රියාවට නැංවීමේදී ඔබට සැමවිටම අවශ්‍ය වන්නේ repr()[හෝ %rහැඩතල ගැන්වීම, සමානව] __repr__, නැතහොත් ඔබ නැවත කිරීමේ ඉලක්කය පරාජය කිරීමයි. ඔබ හඳුනා ගැනීමට හැකි වීමට අවශ්ය MyClass(3)හා MyClass("3").

කිරීමේ ඉලක්කය __str__වනුයේ හොඳින් කියවිය හැකි විය

නිශ්චිතවම, එය නිසැක වීමට අදහස් නොකෙරේ - එය සැලකිල්ලට ගන්න str(3)==str("3"). ඒ හා සමානව, ඔබ IP සාරාංශයක් ක්‍රියාත්මක කරන්නේ නම්, එහි නූල් 192.168.1.1 ලෙස පෙනීම හොඳයි. දිනයක් / වේලාවක් සාරාංශයක් ක්‍රියාත්මක කිරීමේදී, str එක "2010/4/12 15:35:22" විය හැකිය. නිෂ් less ල ඉලක්කම් කපා දමන්න, වෙනත් පංතියක් ලෙස පෙනී සිටින්න - එය කියවීමේ හැකියාව සඳහා සහය දක්වන තාක් කල් එය වැඩිදියුණු කිරීමකි.

රුවනයකි ගේ __str__භාවිතා අඩංගු වස්තූන් '__repr__

මෙය පුදුම සහගත බවක් පෙනේ, එසේ නොවේ ද? එය ටිකක්, නමුත් එය ඒවා භාවිතා කරන්නේ නම් එය කොතරම් කියවිය __str__හැකිද?

[moshe is, 3, hello
world, this is a list, oh I don't know, containing just 4 elements]

එතරම් නොවේ. නිශ්චිතවම, කන්ටේනරයක ඇති නූල් එහි නූල් නිරූපණයට බාධා කිරීම පහසු නැත. අපැහැදිලි තත්වයන් හමුවේ, මතක තබා ගන්න, අනුමාන කිරීමට ඇති පෙළඹවීමට පයිතන් ප්‍රතිරෝධය දක්වයි. ඔබ ලැයිස්තුවක් මුද්‍රණය කරන විට ඉහත හැසිරීම ඔබට අවශ්‍ය නම්

print "[" + ", ".join(l) + "]"

(ශබ්ද කෝෂ සම්බන්ධයෙන් කුමක් කළ යුතු දැයි ඔබට බොහෝ විට හඳුනාගත හැකිය.

සාරාංශය

ඔබ ක්‍රියාත්මක __repr__කරන ඕනෑම පන්තියක් සඳහා ක්‍රියාත්මක කරන්න. මෙය දෙවන ස්වභාවය විය යුතුය. __str__කියවීමේ හැකියාව පැත්තෙන් වැරදි වන නූල් අනුවාදයක් තිබීම ප්‍රයෝජනවත් යැයි ඔබ සිතන්නේ නම් ක්‍රියාත්මක කරන්න.


160
නිදොස් කිරීම යනු යා යුතු මාර්ගය නොවන බවට ඔබේ මතය නිසැකවම එකඟ නොවේ. සංවර්ධනය සඳහා නිෂ්පාදන භාවිතය සඳහා ල ging ු-සටහන් (සහ / හෝ ල ging ු-සටහන්) භාවිතා කරන්න. නිදොස්කරණය කරන්නෙකු සමඟ ඔබට ගැටළුව ඇති වූ විට වැරදුණු සියල්ල පිළිබඳ අදහසක් ඇත. ඔබට සම්පූර්ණ පින්තූරය දැකිය හැකිය. ඔබ සෑම දෙයක්ම ලොග් නොකරන්නේ නම් ඔබට එය ලබා ගත නොහැක. ප්ලස් ඔබ යන සෑම දෙයක්ම ලොග් කරන්නේ නම් ඔබට අවශ්‍ය දේ ලබා ගැනීම සඳහා ටොන් ගණනක් දත්ත හරහා යා යුතුය.
සැමුවෙල්

21
නියම පිළිතුර (නිදොස්කරණය භාවිතා නොකිරීම පිළිබඳ සුළු හැර). පයිතන් 3 හි str vs යුනිකෝඩ් පිළිබඳ වෙනත් ප්‍රශ්නෝත්තරයකට සබැඳියක් එක් කිරීමට මම කැමතියි, එය ස්විචය සෑදූ පුද්ගලයින් සඳහා වන සාකච්ඡාවට අදාළ විය හැකිය.
ThatAintWorking

11
නිදොස්කරණය කරන්නන් සඳහා ප්ලස් 1 නිෂ් less ල වන අතර සතයක්වත් වටිනාකමක් නොදක්වන්න. ඒ වෙනුවට ඔබේ ලොග් වීමේ ප්‍රතිදානය ලබා ගන්න. ඔව්, මෙය හොඳින් ලියා ඇති තනතුරකි. මාරුවෙන් මාරුවට සිදු __repr__මම දෝෂහරණ සඳහා අවශ්ය දේ විය. ඔයාගේ සහායට ස්තූතියි.
personal_cloud

7
ඔබේ නිදොස් කිරීමේ මෝඩකම පසෙකට දමා, මම% r ඉගෙන ගත් අතර එය කෙසේ හෝ ඡන්දය දීම වටී
මිකී පර්ල්ස්ටයින්

7
නිදොස්කරණයට එදිරිව නිදොස්කරණය කරන්නෙකු මත: එවැනි ශක්තිමත් අදහස් ලබා නොගන්න. සමහර යෙදුම්වල නිදොස්කරණය යථාර්ථවාදී නොවේ, සාමාන්‍යයෙන් තත්‍ය කාලීනව සම්බන්ධ වූ විට හෝ ඔබේ කේතය දුරස්ථව ක්‍රියාත්මක වන්නේ සුළු ප්‍රවේශයක් හෝ කොන්සෝලයක් නොමැති වේදිකාවක පමණි. වෙනත් බොහෝ අවස්ථාවන්හිදී, විමර්ශනය කිරීම සඳහා ව්‍යතිරේකයක් නැවැත්වීම හෝ කඩිනම් ස්ථානයක් සැකසීම වඩා ඉක්මන් වනු ඇත, මන්ද ඔබට දහස් ගණනක් ල ging ු-සටහන් හරහා යා යුතු නැත (එමඟින් ඔබේ තැටිය අවුල් වී යෙදුම මන්දගාමී වනු ඇත). අවසාන වශයෙන්, ලොග් වීම සැමවිටම කළ නොහැක, උදාහරණයක් ලෙස කාවැද්දූ උපාංගවල, නිදොස්කරණය ඔබේ මිතුරා ද වේ.
RedGlyph

527

මගේ නියමය: __repr__සංවර්ධකයින් __str__සඳහා, ගනුදෙනුකරුවන් සඳහා ය.


2
මෙය සත්‍ය වන්නේ obj = uuid.uuid1 () සඳහා, obj .__ str __ () "2d7fc7f0-7706-11e9-94ae-0242ac110002" සහ obj .__ repr __ () යනු "UUID ('2d7fc7f0-7706-11e9-94ae-024 ') ". සංවර්ධකයින්ට අවශ්‍යය (අගය + සම්භවය) නමුත් ගනුදෙනුකරුවන්ට වටිනාකමක් අවශ්‍ය වන අතර ඔවුන් එය ලබාගත්තේ කෙසේදැයි ඔවුන් ගණන් ගන්නේ නැත!
නරේන් යෙලාවුල

2
මෙහිදී පාරිභෝගිකයා අවසාන පරිශීලකයා යන්නෙන් අදහස් නොකෙරේ. එය වස්තුවේ සේවාදායකයා හෝ පරිශීලකයා ය. එබැවින් එහි SDK එකක් __str__නම් සාමාන්‍ය සංවර්ධකයින්ට කියවිය හැකි වස්තුවක් ඇති බැවින් SDK සංවර්ධකයින් භාවිතා කරනු ඇත . අනෙක් අතට, __repr__SDK සංවර්ධකයින් සඳහාම වේ.
ෂිප්ලු මොකාඩිම්

400

වෙනත් ආකාරයකින් සහතික කිරීම සඳහා ඔබ විශේෂයෙන් ක්‍රියා නොකරන්නේ නම්, බොහෝ පන්තිවලට මේ සඳහා ප්‍රයෝජනවත් ප්‍රති results ල නොමැත:

>>> class Sic(object): pass
... 
>>> print str(Sic())
<__main__.Sic object at 0x8b7d0>
>>> print repr(Sic())
<__main__.Sic object at 0x8b7d0>
>>> 

ඔබ දකින පරිදි - වෙනසක් නැත, සහ පංතියෙන් සහ වස්තුවෙන් ඔබ්බට තොරතුරු නොමැත id. ඔබ මේ දෙකෙන් එකක් පමණක් ඉක්මවා ගියහොත් ...:

>>> class Sic(object): 
...   def __repr__(object): return 'foo'
... 
>>> print str(Sic())
foo
>>> print repr(Sic())
foo
>>> class Sic(object):
...   def __str__(object): return 'foo'
... 
>>> print str(Sic())
foo
>>> print repr(Sic())
<__main__.Sic object at 0x2617f0>
>>> 

ඔබ දකින පරිදි, ඔබ ඉක්මවා ගියහොත් __repr__, එය ද භාවිතා කරනු ලැබේ __str__, නමුත් අනෙක් අතට නොවේ.

දැන ගැනීමට වෙනත් තීරණාත්මක tidbits: __str__ඉදි කොට මත රුවනයකි මත භාවිතා __repr__නොව, __str__එය අන්තර්ගත අයිතම සඳහා,. සාමාන්‍ය ලියකියවිලි වල ඇති වචන තිබියදීත්, සමාන වස්තුවක් තැනීම සඳහා භාවිතා __repr__කළ evalහැකි නූලක් බවට වස්තූන් සෑදීම ගැන කිසිවෙකු කරදර වන්නේ නැත (එය ඉතා අසීරු ය, අදාළ මොඩියුලය ඇත්ත වශයෙන්ම ආනයනය කළේ කෙසේදැයි නොදැන එය සැබවින්ම කරයි පැතලි කළ නොහැකි).

එබැවින්, මගේ අවවාදය: __str__සාධාරණ ලෙස මානව කියවිය හැකි සහ __repr__ඔබට හැකි තරම් සැක සහිත ලෙස අවධානය යොමු කරන්න, එමඟින් __repr__ආපසු ලැබිය හැකි වටිනාකම ආදානය ලෙස පිළිගත හැකි බවට පත් කර ගැනීමේ නොපැහැදිලි ඉලක්කයට එය බාධා කළත් __eval__!


34
මගේ ඒකක පරීක්ෂණ වලදී මම සෑම විටම eval(repr(foo))සමාන වස්තුවකට තක්සේරු කරනවාදැයි පරීක්ෂා කරමි foo. මොඩියුලය ආනයනය කරන්නේ කෙසේදැයි මා නොදන්නා බැවින් එය මගේ පරීක්ෂණ අවස්ථාවන්ට පිටින් ක්‍රියා නොකරන බව ඔබ නිවැරදිය, නමුත් මෙය අවම වශයෙන් එය කිසියම් පුරෝකථනය කළ හැකි සන්දර්භයක් තුළ ක්‍රියාත්මක වන බව සහතික කරයි . ප්‍රති result __repr__ලය ප්‍රමාණවත් තරම් පැහැදිලි නම් මෙය ඇගයීමට හොඳ ක්‍රමයක් යැයි මම සිතමි . ඒකක පරීක්ෂණයකදී මෙය __repr__සිදු කිරීම පන්තියේ වෙනස්කම් පහත දැක්වෙන බව සහතික කිරීමට උපකාරී වේ.
ස්ටීවන් ටී. ස්නයිඩර්

4
මම සෑම විටම උත්සාහ කරන්නේ එක්කෝ eval(repr(spam)) == spam(අවම වශයෙන් නිවැරදි සන්දර්භය තුළ), හෝ eval(repr(spam))මතු කරයි SyntaxError. ඒ ආකාරයෙන් ඔබ ව්යාකූලත්වය වළක්වයි. (ඒ තියෙන්නේ පාහේ මෙම builtins සඳහා සත්ය හා stdlib බොහෝ, හැර, උදා, ආවර්තනික එහිදී ලැයිස්තු, a=[]; a.append(a); print(eval(repr(a)))ඔබ ලබා දෙන [[Ellipses]]...) ඇත්ත ඇත්තටම මම ඒක කරන්න එපා භාවිතා eval(repr(spam)) ඒකකය පරීක්ෂණ තුළ සාමය චෙක්පතක් ලෙස හැර, ... නමුත් මම නැහැ සමහර විට පිටපත් කර අලවන්න repr(spam)අන්තර් ක්රියාකාරී සැසිය පටන් ගෙන.
abarnert

__str__ඒ වෙනුවට එක් එක් මූලද්‍රව්‍යය සඳහා බහාලුම් (ලැයිස්තු, ටුපල්) භාවිතා නොකරන්නේ ඇයි __repr__? __str__මගේ වස්තුවෙහි කියවිය හැකි දෙයක් ක්‍රියාවට නංවා ඇති අතර එය ලැයිස්තුවක කොටසක් වන විට ඒ __repr__වෙනුවට කැත බව මට පෙනේ .
සුපර්ජියෝ

බිල්ඩින් eval(repr(x))වර්ග සඳහා පවා අසමත් වන කාරණයට අදාළ කරදරකාරී දෝෂයකට හසු වී ඇත: class A(str, Enum): X = 'x'සින්ටැක්ස් දෝෂය ක්‍රියාත්මක eval(repr(A.X))වේ. එය කණගාටුදායක නමුත් තේරුම්ගත හැකි ය. BTW, eval(str(A.X))ඇත්ත වශයෙන්ම ක්‍රියාත්මක වේ, නමුත් ඇත්ත වශයෙන්ම class Aවිෂය පථයේ තිබේ නම් පමණි - එබැවින් එය බොහෝ සෙයින් ප්‍රයෝජනවත් නොවේ.
උපරිම

රුවනයකි: @SuperGeo වෙනත් පිළිතුරු මෙම ආවරණය strභාවිතා අංගයක් reprනිසා [1, 2, 3]=! ["1", "2, 3"].
mtraceur

165

__repr__: සාමාන්‍යයෙන් evt python object නිරූපණය කිරීමෙන් එය නැවත එම වස්තුව බවට පරිවර්තනය වේ

__str__: ඔබ සිතන ඕනෑම දෙයක් එම වස්තුව පෙළ ස්වරූපයෙන් වේ

උදා

>>> s="""w'o"w"""
>>> repr(s)
'\'w\\\'o"w\''
>>> str(s)
'w\'o"w'
>>> eval(str(s))==s
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "<string>", line 1
    w'o"w
       ^
SyntaxError: EOL while scanning single-quoted string
>>> eval(repr(s))==s
True

152

කෙටියෙන් කිවහොත්, ඉලක්කය __repr__වන්නේ නිසැකය සහ __str__කියවිය හැකි වීමයි.

මෙන්න හොඳ උදාහරණයක්:

>>> import datetime
>>> today = datetime.datetime.now()
>>> str(today)
'2012-03-14 09:21:58.130922'
>>> repr(today)
'datetime.datetime(2012, 3, 14, 9, 21, 58, 130922)'

Repr සඳහා මෙම ලේඛනය කියවන්න:

repr(object)

වස්තුවක මුද්‍රණය කළ හැකි නිරූපණයක් අඩංගු නූලක් ආපසු එවන්න. පරිවර්තන (ප්‍රතිලෝම උපුටා දැක්වීම්) මඟින් ලබා දෙන අගය මෙයයි. සාමාන්‍ය ශ්‍රිතයක් ලෙස මෙම මෙහෙයුමට ප්‍රවේශ වීම සමහර විට ප්‍රයෝජනවත් වේ. බොහෝ වර්ග සඳහා, මෙම ශ්‍රිතය වස්තුවක් ලබා දෙන විට එකම අගයක් ලබා දෙන නූලක් ආපසු ලබා දීමට උත්සාහ කරයි eval(), එසේ නොමැතිනම් නිරූපණය යනු කෝණික වරහන් තුළ කොටා ඇති නූලක් වන අතර එමඟින් වස්තුවේ වර්ගය සහ අතිරේක තොරතුරු ඇතුළත් වේ. බොහෝ විට වස්තුවේ නම සහ ලිපිනය ඇතුළත් වේ. __repr__()ක්‍රමයක් නිර්වචනය කිරීමෙන් පන්තියකට මෙම ශ්‍රිතය එහි අවස්ථාවන් සඳහා ලැබෙන දේ පාලනය කළ හැකිය .

මෙන්න str සඳහා ලියකියවිලි:

str(object='')

වස්තුවක මනාව මුද්‍රණය කළ හැකි නිරූපණයක් අඩංගු නූලක් ආපසු එවන්න. නූල් සඳහා, මෙය නූල් නැවත ලබා දෙයි. මෙහි ඇති වෙනස repr(object)නම් str(object)සෑම විටම පිළිගත හැකි නූලක් ආපසු ලබා දීමට උත්සාහ නොකිරීම eval(); එහි ඉලක්කය වන්නේ මුද්‍රණය කළ හැකි නූලක් ආපසු ලබා දීමයි. තර්කයක් ලබා දී නොමැති නම්, හිස් නූල නැවත ලබා දෙන්න ''.


1
මෙහි මුද්‍රණය කළ හැකි නූල් වල තේරුම කුමක්ද? කරුණාකර ඔබට එය පැහැදිලි කළ හැකිද?
වික්‍රොබොට්

115

පයිතන් අතර __str__සහ වෙනස __repr__කුමක්ද?

__str__("dunder (double-underscore) string" __repr__ලෙස කියවන්න ) සහ ("dunder-repper" ("නිරූපණය" සඳහා කියවන්න)) දෙකම වස්තුවේ තත්වය මත පදනම්ව නූල් ආපසු ලබා දෙන විශේෂ ක්‍රම වේ.

__repr____str__අස්ථානගත වී ඇත්නම් උපස්ථ හැසිරීම සපයයි .

එබැවින් යමෙකු පළමුවෙන්ම ලිවිය යුත්තේ __repr__එය නැවත ලබා දෙන නූලෙන් සමාන වස්තුවක් නැවත ස්ථාපනය කිරීමට ඔබට ඉඩ සලසයි. උදා: evalපයිතන් කවචයක අක්ෂර-අක්ෂර සඳහා එය ටයිප් කිරීම.

ඕනෑම වේලාවක, යමෙකුට __str__එය අවශ්‍ය යැයි විශ්වාස කරන විට, පරිශීලකයාට කියවිය හැකි නූල් නිරූපණය සඳහා ලිවිය හැකිය.

__str__

ඔබ වස්තුව මුද්රණය කිරීම, හෝ එය සමත් නම් format, str.formatහෝ str, පසුව නම් __str__ක්රමය, අර්ථ ක්රමය කැඳවන බව, වෙනත් ආකාරයකින්, __repr__භාවිතා කරනු ඇත.

__repr__

මෙම __repr__ක්‍රමය බිල්ඩින් ශ්‍රිතය මගින් හැඳින්වෙන අතර reprඑය වස්තුවක් ආපසු ලබා දෙන ප්‍රකාශනයක් තක්සේරු කරන විට ඔබේ පයිතන් කවචයේ දෝංකාර දෙයි.

එය උපස්ථයක් සපයන බැවින් __str__, ඔබට එකක් පමණක් ලිවිය හැකි නම්, ආරම්භ කරන්න__repr__

මෙන්න බිල්ඩින් උදව් repr:

repr(...)
    repr(object) -> string

    Return the canonical string representation of the object.
    For most object types, eval(repr(object)) == object.

එනම්, බොහෝ වස්තූන් සඳහා, ඔබ මුද්‍රණය කළ දේ ටයිප් කරන්නේ නම් repr, ඔබට සමාන වස්තුවක් නිර්මාණය කිරීමට හැකි විය යුතුය. නමුත් මෙය සුපුරුදු ලෙස ක්‍රියාත්මක කිරීම නොවේ.

පෙරනිමිය ක්‍රියාත්මක කිරීම __repr__

පෙරනිමි වස්තුව __repr__( C Python source ) වැනි දෙයක්:

def __repr__(self):
    return '<{0}.{1} object at {2}>'.format(
      self.__module__, type(self).__name__, hex(id(self)))

ඒ කියන්නේ පෙරනිමියෙන් ඔබ වස්තුවෙන් පැමිණි මොඩියුලය, පන්තියේ නම සහ මතකයේ එහි පිහිටීමෙහි ෂඩාස්රාකාර නිරූපණය මුද්‍රණය කරයි - උදාහරණයක් ලෙස:

<__main__.Foo object at 0x7f80665abdd0>

මෙම තොරතුරු ඉතා ප්‍රයෝජනවත් නොවේ, නමුත් ඕනෑම අවස්ථාවක කැනොනිකල් නිරූපණයක් නිවැරදිව නිර්මාණය කරන්නේ කෙසේද යන්න ව්‍යුත්පන්න කිරීමට ක්‍රමයක් නොමැත, එය කිසි දෙයකට වඩා හොඳ නැත, අවම වශයෙන් එය මතකයේ අද්විතීය ලෙස හඳුනා ගන්නේ කෙසේදැයි අපට කියා දෙයි.

කෙසේ හැකි __repr__ප්රයෝජනවත් විය?

පයිතන් කවචය සහ datetimeවස්තූන් භාවිතා කරමින් එය කෙතරම් ප්‍රයෝජනවත් වේදැයි සොයා බලමු . පළමුව අපි datetimeමොඩියුලය ආනයනය කළ යුතුයි :

import datetime

අපි datetime.nowකවචයට කතා කළහොත් , අපට සමාන දිවා කාල වස්තුවක් ප්‍රතිනිර්මාණය කිරීමට අවශ්‍ය සියල්ල අපට පෙනෙනු ඇත. මෙය නිර්මාණය කර ඇත්තේ දිවා කාලය __repr__:

>>> datetime.datetime.now()
datetime.datetime(2015, 1, 24, 20, 5, 36, 491180)

අපි දිවා කාලයේ වස්තුවක් මුද්‍රණය කරන්නේ නම්, අපට කියවිය හැකි ලස්සන (ඇත්ත වශයෙන්ම, ISO) ආකෘතියක් අපට පෙනේ. මෙය ක්‍රියාත්මක වන්නේ දිවා කාලයේ __str__:

>>> print(datetime.datetime.now())
2015-01-24 20:05:44.977951

අපට අහිමි වූ වස්තුව ප්‍රතිනිර්මාණය කිරීම සරල කාරණයකි, මන්ද එය __repr__ප්‍රතිදානය පිටපත් කර ඇලවීම මගින් විචල්‍යයකට අප විසින් පවරා නොතිබූ අතර පසුව එය මුද්‍රණය කර අනෙක් වස්තුව මෙන් ම කියවිය හැකි නිමැවුමකින් එය ලබා ගනිමු:

>>> the_past = datetime.datetime(2015, 1, 24, 20, 5, 36, 491180)
>>> print(the_past)
2015-01-24 20:05:36.491180

ඒවා ක්‍රියාත්මක කරන්නේ කෙසේද?

ඔබ දියුණු වන විට, හැකි නම් එකම තත්වයේ ඇති වස්තූන් ප්‍රතිනිෂ්පාදනය කිරීමට ඔබට අවශ්‍ය වනු ඇත. නිදසුනක් ලෙස, දිවා කාල වස්තුව අර්ථ දක්වන ආකාරය මෙයයි __repr__( පයිතන් ප්‍රභවය ). එවැනි වස්තුවක් ප්‍රතිනිෂ්පාදනය කිරීමට අවශ්‍ය සියලු ගුණාංග නිසා එය තරමක් සංකීර්ණ ය:

def __repr__(self):
    """Convert to formal string, for repr()."""
    L = [self._year, self._month, self._day,  # These are never zero
         self._hour, self._minute, self._second, self._microsecond]
    if L[-1] == 0:
        del L[-1]
    if L[-1] == 0:
        del L[-1]
    s = "%s.%s(%s)" % (self.__class__.__module__,
                       self.__class__.__qualname__,
                       ", ".join(map(str, L)))
    if self._tzinfo is not None:
        assert s[-1:] == ")"
        s = s[:-1] + ", tzinfo=%r" % self._tzinfo + ")"
    if self._fold:
        assert s[-1:] == ")"
        s = s[:-1] + ", fold=1)"
    return s

ඔබේ වස්තුවට වඩා මානව කියවිය හැකි නිරූපණයක් ලබා ගැනීමට ඔබට අවශ්‍ය නම්, ඔබට __str__ඊළඟට ක්‍රියාත්මක කළ හැකිය . ඩේටයිම් වස්තුව ( පයිතන් ප්‍රභවය ) ක්‍රියාත්මක කරන ආකාරය මෙන්න __str__, එය අයිඑස්ඕ ආකෘතියෙන් ප්‍රදර්ශනය කිරීමට දැනටමත් ශ්‍රිතයක් ඇති බැවින් එය පහසුවෙන් කරයි:

def __str__(self):
    "Convert to string, for str()."
    return self.isoformat(sep=' ')

සකසා __repr__ = __str__තිබේද?

මෙය සැකසීමට යෝජනා කරන තවත් පිළිතුරක විවේචනයකි __repr__ = __str__.

සැකසුම __repr__ = __str__මෝඩයි - __repr__එය පසුබෑමක් වන __str__අතර __repr__, නිදොස් කිරීමේ දී සංවර්ධකයින්ගේ භාවිතය සඳහා ලියා ඇති a , ඔබ ලිවීමට පෙර ලිවිය යුතුය __str__.

ඔබට අවශ්‍ය __str__වන්නේ ඔබට වස්තුවෙහි පෙළ නිරූපණයක් අවශ්‍ය වූ විට පමණි.

නිගමනය

__repr__ඔබ ලියන වස්තූන් සඳහා නිර්වචනය කරන්න, එවිට ඔබ සහ අනෙකුත් සංවර්ධකයින් එය වර්ධනය වන විට එය භාවිතා කරන විට ප්‍රජනනය කළ හැකි ආදර්ශයක් ඇත. __str__ඔබට එය කියවිය හැකි මිනිස් නිරූපණයක් අවශ්‍ය විට නිර්වචනය කරන්න .


එය යම් දෙයක් විය යුතු type(obj).__qualname__නොවේද?
සොලමන් උකෝ

@ සොලමන් උකෝ ඔව් පයිතන් 3 හි එය එසේ වනු ඇත - මෙය ක්‍රියාත්මක කරන ලද ප්‍රභව කේතය මම දඩයම් කර ඇති අතර මම එය ලබා ගත් විට එම තොරතුරු සමඟ මගේ පිළිතුර යාවත්කාලීන කරමි.
ආරොන් හෝල්

33

හාන්ස් පීටර් ලැන්ග්ටැන්ගන් විසින් පරිගණක විද්‍යාව සඳහා පයිතන් ස්ක්‍රිප්ටින් පොතේ 358 වන පිටුවේ එය පැහැදිලිව සඳහන් කරයි

  • මෙම __repr__වස්තුව පිළිබඳ සම්පූර්ණ string නියෝජන දී අරමුණු කවරේද;
  • මෙම __str__මුද්රණය සඳහා කදිම string නැවත පැමිණීමට නියමිත ය.

ඒ නිසා, මම ඒවා තේරුම් ගැනීමට කැමතියි

  • repr = ප්‍රජනනය
  • str = string (නිරූපණය)

පරිශීලකයාගේ දෘෂ්ටි කෝණයෙන් මෙය පයිතන් ඉගෙන ගැනීමේදී මා කළ වරදවා වටහා ගැනීමකි.

කුඩා නමුත් හොඳ උදාහරණයක් පහත දැක්වෙන පිටුවේම ලබා දී ඇත:

උදාහරණයක්

In [38]: str('s')
Out[38]: 's'

In [39]: repr('s')
Out[39]: "'s'"

In [40]: eval(str('s'))
Traceback (most recent call last):

  File "<ipython-input-40-abd46c0c43e7>", line 1, in <module>
    eval(str('s'))

  File "<string>", line 1, in <module>

NameError: name 's' is not defined


In [41]: eval(repr('s'))
Out[41]: 's'

එය pg වේ. # 351.
jiten

4
reprප්‍රජනනය ලෙස හැඳින්වීම නොමඟ යවන සුළුය . එය නියෝජනය කිරීමක් ලෙස සිතීම වඩා හොඳය.
නෙල්සන්ගොන්

32

ලබා දී ඇති සියලුම පිළිතුරු වලට අමතරව, කරුණු කිහිපයක් එක් කිරීමට මම කැමතියි: -

1) __repr__()ඔබ හුදෙක් අන්තර්ක්‍රියාකාරී පයිතන් කොන්සෝලය මත වස්තුවේ නම ලියා එන්ටර් ඔබන්න.

2) __str__()ඔබ මුද්‍රණ ප්‍රකාශය සමඟ වස්තුව භාවිතා කරන විට ආයාචනය කරනු ලැබේ.

3) __str__අස්ථානගත වී ඇත්නම් , මුද්‍රණය කර කිසියම් කාර්යයක් වස්තු str()ආයාචනා භාවිතා කරයි __repr__().

4) __str__()බහාලුම්, ආයාචනා කළ විට __repr__()එහි අඩංගු මූලද්‍රව්‍යයන්ගේ ක්‍රමය ක්‍රියාත්මක වේ.

5) str()ඇතුළත කැඳවීම __str__()පදනම් නඩුවකින් තොරව පුනරාවර්තනය විය හැකි අතර උපරිම පුනරාවර්තන ගැඹුරේ දෝෂයකි.

6) __repr__()ඇමතුමක් repr()ලබා ගත හැකි අතර එය අනන්ත පුනරාවර්තනය ස්වයංක්‍රීයව වළක්වා ගැනීමට උත්සාහ කරයි ....


14

සරලව කිවහොත්:

__str__අන් අයට පහසුවෙන් කියවිය හැකි ඔබේ වස්තුවෙහි තන්තු නිරූපණයක් පෙන්වීමට භාවිතා කරයි.

__repr__වැලක් නියෝජන පෙන්වන්න භාවිතා වන වස්තුවක්.

Fractionභාගයක නූල් නිරූපණය '(1/2)' සහ වස්තුව (භාග පංතිය) 'භාගය (1,2)' ලෙස නිරූපණය කළ යුතු පන්තියක් නිර්මාණය කිරීමට මට අවශ්‍ය යැයි කියමු .

එබැවින් අපට සරල භාග පංතියක් නිර්මාණය කළ හැකිය:

class Fraction:
    def __init__(self, num, den):
        self.__num = num
        self.__den = den

    def __str__(self):
        return '(' + str(self.__num) + '/' + str(self.__den) + ')'

    def __repr__(self):
        return 'Fraction (' + str(self.__num) + ',' + str(self.__den) + ')'



f = Fraction(1,2)
print('I want to represent the Fraction STRING as ' + str(f)) # (1/2)
print('I want to represent the Fraction OBJECT as ', repr(f)) # Fraction (1,2)

13

සෑම අවංකකමකින්ම, eval(repr(obj))කිසි විටෙකත් භාවිතා නොවේ. ඔබ එය භාවිතා කරන බව පෙනේ නම්, ඔබ නැවැත්විය යුතුය, මන්ද evalඑය භයානක වන අතර, නූල් යනු ඔබේ වස්තූන් අනුක්‍රමික කිරීමට ඉතා අකාර්යක්ෂම ක්‍රමයකි ( pickleඒ වෙනුවට භාවිතා කරන්න).

එබැවින්, සැකසීමට මම නිර්දේශ කරමි __repr__ = __str__. හේතුව බව ය str(list)ඇමතුම් reprමූලද්රව්ය මත (මම මේ Python 3 ආමන්ත්රණය කර නැති බව Python විශාලතම නිර්මාණ එතරම්ම සාර්ථකත්වයක් එකක් වෙන්න සලකා). සත්‍යයක් reprබොහෝ විට ප්‍රතිදානය ලෙස එතරම් ප්‍රයෝජනවත් නොවනු ඇත print [your, objects].

මෙය සුදුසුකම් ලැබීම සඳහා, මගේ අත්දැකීම් අනුව, reprශ්‍රිතයේ වඩාත්ම ප්‍රයෝජනවත් අවස්ථාව වන්නේ වෙනත් නූලක් තුළ නූලක් තැබීමයි (නූල් හැඩතල ගැන්වීම භාවිතා කිරීම). මේ ආකාරයෙන්, ඔබ උපුටා දැක්වීම් හෝ වෙනත් කිසිවක් ගැන කරදර විය යුතු නැත. නමුත් evalමෙහි කිසිදු දෙයක් සිදු නොවන බව සලකන්න .


19
මම හිතන්නේ මේ කාරණය මග හැරී ඇත. භාවිතය eval(repr(obj))සනීපාරක්ෂක පරීක්‍ෂණයක් සහ නියමාකාර නීතියක් - මෙය මුල් වස්තුව නිවැරදිව ප්‍රතිනිර්මාණය කරන්නේ නම් ඔබට හොඳ __repr__ක්‍රියාත්මක කිරීමක් තිබේ. ඔබ සැබවින්ම වස්තු මේ ආකාරයෙන් අනුක්‍රමික කිරීම අදහස් නොකෙරේ.
jwg

7
evalසහජයෙන්ම භයානක නොවේ. වඩා භයානක නොවේ unlink, openහෝ ගොනු වෙත ලිඛිතව. අනිෂ්ට ප්‍රහාරයකින් අන්තර්ගතය ඇතුලත් කිරීමට අත්තනෝමතික ගොනු මාර්ගයක් භාවිතා කළ හැකි නිසා අපි ලිපිගොනු වලට ලිවීම නතර කළ යුතුද? ගොළු අය ගොළු ලෙස භාවිතා කරන්නේ නම් සියල්ල භයානක ය. මෝඩකම භයානකයි. ඩනිං-කෘගර් බලපෑම් භයානක ය. evalශ්‍රිතයක් පමණි.
ලුයිස් මසුලි

12

සිට ක (නිල නොවන) Python විමර්ශන විකිපීඩියා, නිදහස් විශ්වකෝෂය (සංරක්ෂිත පිටපතක්) effbot ලද්දේ:

__str__" වස්තුවක" අවිධිමත් "නූල් නිරූපණය ගණනය කරයි. මෙය __repr__වලංගු පයිතන් ප්‍රකාශනයක් විය යුතු බවට වඩා වෙනස් වේ : ඒ වෙනුවට වඩාත් පහසු හෝ සංක්ෂිප්ත නිරූපණයක් භාවිතා කළ හැකිය. "


3
__repr__වයිල්ඩ් පයිතන් ප්‍රකාශනයක් නැවත ලබා දීමට කිසිසේත් අවශ්‍ය නොවේ.
පිස්සු භෞතික විද්‍යා

10

str - දී ඇති වස්තුවෙන් නව සංගීත වස්තුවක් සාදයි.

repr - වස්තුවෙහි කැනොනිකල් නූල් නිරූපණය ලබා දෙයි.

වෙනස්කම්:

str ():

  • වස්තුව කියවිය හැකි කරයි
  • අවසාන පරිශීලකයා සඳහා ප්‍රතිදානය ජනනය කරයි

repr ():

  • වස්තුව ප්‍රතිනිෂ්පාදනය කරන කේතයක් අවශ්‍යයි
  • සංවර්ධකයා සඳහා ප්‍රතිදානය ජනනය කරයි

8

අනෙක් පිළිතුරු වල නැති එක් අංගයක්. පොදුවේ රටාව මෙය බව සත්‍යයකි:

  • ඉලක්කය __str__: මිනිස් කියවිය හැකි
  • ඉලක්කය __repr__: සැක සහිත, සමහර විට යන්ත්‍ර කියවිය හැකි යeval

අවාසනාවකට මෙන්, මෙම අවකලනය දෝෂ සහිත ය, මන්ද යත්, පයිතන් REPL සහ IPython __repr__REPL කොන්සෝලය තුළ වස්තු මුද්‍රණය කිරීම සඳහා භාවිතා කරන බැවිනි ( පයිතන් සහ IPython සඳහා අදාළ ප්‍රශ්න බලන්න ). මේ අනුව, අන්තර්ක්‍රියාකාරී කොන්සෝල වැඩ සඳහා ඉලක්ක කර ඇති ව්‍යාපෘති (උදා: නැම්පි හෝ පැන්ඩා) ඉහත නීති නොසලකා හැර __repr__ඒ වෙනුවට මිනිසුන්ට කියවිය හැකි ක්‍රියාත්මක කිරීමක් ලබා දීමට පටන් ගෙන තිබේ.


7

Fluent Python පොතෙන් :

පයිතන් වස්තුවක් සඳහා මූලික අවශ්‍යතාවයක් වන්නේ තමන් විසින්ම භාවිතා කළ හැකි නූල් නිරූපණයන් සැපයීමයි, එකක් නිදොස්කරණය සහ ලොග් වීම සඳහා භාවිතා කරන අතර තවත් එකක් අවසාන පරිශීලකයින්ට ඉදිරිපත් කිරීම සඳහා ය.
විශේෂ ආකෘතීන් __repr__සහ __str__දත්ත ආකෘතියේ පවතින්නේ එබැවිනි .


5

විශිෂ් answer පිළිතුරු දැනටමත් __str__සහ අතර වෙනස ආවරණය කරයි __repr__, එය කලින් පරිශීලකයාට පවා කියවිය හැකි වන අතර, දෙවැන්න සංවර්ධකයින්ට හැකි තරම් ප්‍රයෝජනවත් වේ. ඒ අනුව, __repr__බොහෝ විට පෙරනිමියෙන් ක්‍රියාත්මක කිරීම මෙම ඉලක්කය සපුරා ගැනීමට අසමත් වන බව මට පෙනී යන්නේ එය සංවර්ධකයින්ට ප්‍රයෝජනවත් තොරතුරු මඟ හැරෙන බැවිනි .

මේ හේතුව නිසා, මට ප්‍රමාණවත් තරම් සරල දෙයක් තිබේ නම් __str__, මම සාමාන්‍යයෙන් උත්සාහ කරන්නේ මේ දෙකින්ම ලෝකයේ හොඳම දේ ලබා ගැනීමට ය:

def __repr__(self):
    return '{0} ({1})'.format(object.__repr__(self), str(self))

4

මතක තබා ගත යුතු එක් වැදගත් දෙයක් නම් බහාලුම්වල භාවිතයේ __str__අඩංගු වස්තූන්ය __repr__.

>>> from datetime import datetime
>>> from decimal import Decimal
>>> print (Decimal('52'), datetime.now())
(Decimal('52'), datetime.datetime(2015, 11, 16, 10, 51, 26, 185000))
>>> str((Decimal('52'), datetime.now()))
"(Decimal('52'), datetime.datetime(2015, 11, 16, 10, 52, 22, 176000))"

Python මීට උදාහරණ කියවීමේ පහසුව වැඩි unambiguity උපකාරී වන __str__අ ඇමතුමක් tupleඅඩංගු වස්තූන් 'ඉල්ලා __repr__එම "විධිමත්" වස්තුවක නිරූපණය. විධිමත් නිරූපණය අවිධිමත් එකකට වඩා කියවීමට අපහසු වුවද, එය දෝෂ වලට එරෙහිව නිසැක හා වඩා ශක්තිමත් ය.


එය __repr__ ( __str__) නිර්වචනය කර නොමැති විට එය භාවිතා කරයි ! ඉතින්, ඔබ වැරදියි.
ජිටන්

4

කෙටියෙන්:

class Demo:
  def __repr__(self):
    return 'repr'
  def __str__(self):
    return 'str'

demo = Demo()
print(demo) # use __str__, output 'str' to stdout

s = str(demo) # __str__ is used, return 'str'
r = repr(demo) # __repr__ is used, return 'repr'

import logging
logger = logging.getLogger(logging.INFO)
logger.info(demo) # use __str__, output 'str' to stdout

from pprint import pprint, pformat
pprint(demo) # use __repr__, output 'repr' to stdout
result = pformat(demo) # use __repr__, result is string which value is 'str'

4
>>> print(decimal.Decimal(23) / decimal.Decimal("1.05"))
21.90476190476190476190476190
>>> decimal.Decimal(23) / decimal.Decimal("1.05")
Decimal('21.90476190476190476190476190')

අමු අංකයේ ප්‍රති print()result ලය කැඳවූ විට decimal.Decimal(23) / decimal.Decimal("1.05")මුද්‍රණය කෙරේ; මෙම ප්‍රතිදානය ලබා ගත හැකි නූල් ස්වරූපයෙන් ඇත __str__(). අපි සරලව ප්‍රකාශනයට ඇතුළු වුවහොත් අපට decimal.Decimalප්‍රතිදානයක් ලැබේ - මෙම ප්‍රතිදානය නියෝජන ස්වරූපයෙන් ලබා ගත හැකි අතර එය සාක්ෂාත් කරගත හැකිය __repr__(). සියලුම පයිතන් වස්තු වලට ප්‍රතිදාන ආකාර දෙකක් ඇත. නූල් ආකෘතිය නිර්මාණය කර ඇත්තේ මිනිසුන්ට කියවිය හැකි ආකාරයට ය. නියෝජන ආකෘතිය සැලසුම් කර ඇත්තේ පයිතන් පරිවර්තකයෙකුට පෝෂණය කළහොත් (හැකි විට) නිරූපිත වස්තුව ප්‍රතිනිෂ්පාදනය කරන ප්‍රතිදානය නිපදවීමට ය.


4

__str__ඇමතීමෙන් වස්තුවකට ආයාචනා කළ හැකි str(obj)අතර මිනිස් කියවිය හැකි නූලක් ආපසු ලබා දිය යුතුය.

__repr__ඇමතීමෙන් වස්තුවකට ආයාචනා කළ හැකි අතර repr(obj)අභ්‍යන්තර වස්තුව ආපසු ලබා දිය යුතුය (වස්තු ක්ෂේත්‍ර / ගුණාංග)

මෙම උදාහරණය උදව් විය හැකිය:

class C1:pass

class C2:        
    def __str__(self):
        return str(f"{self.__class__.__name__} class str ")

class C3:        
    def __repr__(self):        
         return str(f"{self.__class__.__name__} class repr")

class C4:        
    def __str__(self):
        return str(f"{self.__class__.__name__} class str ")
    def __repr__(self):        
         return str(f"{self.__class__.__name__} class repr")


ci1 = C1()    
ci2 = C2()  
ci3 = C3()  
ci4 = C4()

print(ci1)       #<__main__.C1 object at 0x0000024C44A80C18>
print(str(ci1))  #<__main__.C1 object at 0x0000024C44A80C18>
print(repr(ci1)) #<__main__.C1 object at 0x0000024C44A80C18>
print(ci2)       #C2 class str
print(str(ci2))  #C2 class str
print(repr(ci2)) #<__main__.C2 object at 0x0000024C44AE12E8>
print(ci3)       #C3 class repr
print(str(ci3))  #C3 class repr
print(repr(ci3)) #C3 class repr
print(ci4)       #C4 class str 
print(str(ci4))  #C4 class str 
print(repr(ci4)) #C4 class repr

3

ඒවා තේරුම් __str__ගෙන __repr__බුද්ධිමත්ව හා ස්ථිරවම වෙන්කර හඳුනා ගන්න.

__str__ඇස් කියවීම සඳහා දී ඇති වස්තුවක වෙස්වළාගත් සිරුර
__repr__ආපසු ලබා දෙන්න.

එය උදාහරණයකින් බලන්න

In [30]: str(datetime.datetime.now())
Out[30]: '2017-12-07 15:41:14.002752'
Disguised in string form

ලෙස __repr__

In [32]: datetime.datetime.now()
Out[32]: datetime.datetime(2017, 12, 7, 15, 43, 27, 297769)
Presence in real body which allows to be manipulated directly.

ප්‍රති __repr__results ල මත ගණිතමය මෙහෙයුමක් අපට පහසුවෙන් කළ හැකිය .

In [33]: datetime.datetime.now()
Out[33]: datetime.datetime(2017, 12, 7, 15, 47, 9, 741521)
In [34]: datetime.datetime(2017, 12, 7, 15, 47, 9, 741521) - datetime.datetime(2
    ...: 017, 12, 7, 15, 43, 27, 297769)
Out[34]: datetime.timedelta(0, 222, 443752)

මෙහෙයුම ක්‍රියාත්මක කරන්නේ නම් __str__

In [35]: '2017-12-07 15:43:14.002752' - '2017-12-07 15:41:14.002752'
TypeError: unsupported operand type(s) for -: 'str' and 'str'

දෝෂයක් හැර අන් කිසිවක් ලබා නොදේ.

තවත් උදාහරණයක්.

In [36]: str('string_body')
Out[36]: 'string_body' # in string form

In [37]: repr('real_body')
Out[37]: "'real_body'" #its real body hide inside

තවත් පිළිතුරු ගවේෂණය කිරීම සඳහා ස්ථිර පදනමක් ගොඩනැගීමට මෙය ඔබට උපකාරී වේ යැයි සිතමු.


3
  1. __str____repr__ඕනෑම පයිතන් ප්‍රකාශනයක් ආපසු ලබා දිය හැකි නමුත් නූල් වස්තුව ආපසු ලබා දිය යුතුය .
  2. __str__ක්‍රියාත්මක කිරීම අස්ථානගත වී ඇත්නම් __repr__ශ්‍රිතය පසුබෑමක් ලෙස භාවිතා කරයි. __repr__ශ්‍රිතය ක්‍රියාත්මක කිරීම අස්ථානගත වී ඇත්නම් පසුබෑමක් නොමැත .
  3. නම් __repr__කාර්යය වස්තුවේ, සංගීත නියෝජනය ආපසු පැමිනෙමින්, අපි ක්රියාත්මක මඟ හැරිය හැක __str__උත්සවය.

මුලාශ්‍රය: https://www.journaldev.com/22460/python-str-repr-functions


2

__repr__ක්‍රම printසහ strක්‍රම හැර සෑම තැනකම භාවිතා වේ (a __str__නිර්වචනය කළ විට !)

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.