Python Hints
اول راجب خود __repr__ بگم برای دوستان تازهکار، در صورتیکه وجود نداشته باشه توی خط 11 و بعد از اجرای کد چیزی که برای شما توی کنسول نمایش داده میشه آدرس حافظه اون object هست مثلاً: <main.Person object at 0x7f894c576650> که خب اصلا چیز خوبی نیست، به لطف…
توی این پست کلی سوال درمورد
!r
شده، این مورد جایگزین تابع repr میشه :
ینی بجای :
f"{self.name!r}"
از
repr(self.name)
استفاده کنید که خب من اصلاً ترجیح نمیدم؛ بعضی دوستان میگن حالت دوم خوانایی بیشتری داره و ... پس باید ازین استفاده بشه
که مخالفم با این صحبت، اگر یک فیچری توی زبان برنامهنویسی هست که کار رو راحت میکنه پس باید ازش استفاده کرد این وظیفه باقی دولوپرها هست که خودشون رو آپدیت کنند.
مثل این میمونه که بگید از
Match-case
استفاده نکنیم چون خیلیها بلد نیستند همون
if-else
تو در تو بهتره
بگذریم، بصورت خلاصه این نمادها و توابع مهم هست :
!r
شده، این مورد جایگزین تابع repr میشه :
ینی بجای :
f"{self.name!r}"
از
repr(self.name)
استفاده کنید که خب من اصلاً ترجیح نمیدم؛ بعضی دوستان میگن حالت دوم خوانایی بیشتری داره و ... پس باید ازین استفاده بشه
که مخالفم با این صحبت، اگر یک فیچری توی زبان برنامهنویسی هست که کار رو راحت میکنه پس باید ازش استفاده کرد این وظیفه باقی دولوپرها هست که خودشون رو آپدیت کنند.
مثل این میمونه که بگید از
Match-case
استفاده نکنیم چون خیلیها بلد نیستند همون
if-else
تو در تو بهتره
بگذریم، بصورت خلاصه این نمادها و توابع مهم هست :
!r : repr()
!s : str()
!a : ascii()
@PyHints👍34❤🔥5❤1👎1
بنظرتون خروجی print چی هست ؟ چرایی قضیه رو هم توضیح بدید ؟
اینم یک سوال مصاحبه هست؛ بخاطر اینکه به نظر گروهی از افراد خروجی عجیب یا اشتباه هست که خب نیست و طبق منطق scope بندی کلاسها توی پایتون کاملا رفتار درست هست.
پ.ن : اینکه میگم سوال مصاحبه منظورم این نیست که دقیقا همین رو و همینقدر ساده میپرسند اما نکتهی مهم سوال این بخش بوده که من بیرون کشیدم و bold کردم تا توی یک پست بشه کامل بهش پرداخت.
@PyHints
اینم یک سوال مصاحبه هست؛ بخاطر اینکه به نظر گروهی از افراد خروجی عجیب یا اشتباه هست که خب نیست و طبق منطق scope بندی کلاسها توی پایتون کاملا رفتار درست هست.
پ.ن : اینکه میگم سوال مصاحبه منظورم این نیست که دقیقا همین رو و همینقدر ساده میپرسند اما نکتهی مهم سوال این بخش بوده که من بیرون کشیدم و bold کردم تا توی یک پست بشه کامل بهش پرداخت.
@PyHints
👍26🤔4🤩1
Python Hints
بنظرتون خروجی print چی هست ؟ چرایی قضیه رو هم توضیح بدید ؟ اینم یک سوال مصاحبه هست؛ بخاطر اینکه به نظر گروهی از افراد خروجی عجیب یا اشتباه هست که خب نیست و طبق منطق scope بندی کلاسها توی پایتون کاملا رفتار درست هست. پ.ن : اینکه میگم سوال مصاحبه منظورم این…
جواب سوال :
سوال ممکنه پیش بیاد: پس متد hello چرا داره classScope رو چاپ میکنه ؟
دلیلش واضح هست چون
اما مورد دوم و سوم ؛
اما چالش سر
@pyHints
classScope says hello
['classScope', 'classScope', 'classScope']
['@pyHints', '@pyHints', '@pyHints']
چیزی که به نظر بعضی افراد عجیب هست رفتار متفاوت list_1, list_2
هست؛ همینجا توضیح بدم که توابع - متدها (انواع متدها منظورم هست چه class bounded
چه instance bounded
و حتی static method
) همگی Scope رو از parent میگیرند توی این کد میشه global :سوال ممکنه پیش بیاد: پس متد hello چرا داره classScope رو چاپ میکنه ؟
دلیلش واضح هست چون
class bound method
هست و خود کلاس رو بعنوان پارارمتر اول میگیره و اتفاقا چون scope خودش گلوبال هست برای دسترسی به classScope باید از cls.name
استفاده کنیم.اما مورد دوم و سوم ؛
list_1
که توی قانون بالا نیست پس scope اش مربوط به خود کلاس هست در نتیجه classScope رو چاپ میکنهاما چالش سر
list_2
هست؛ دلیل اینکه @pyHints
رو چاپ میکنه اینه که یک list comprehension
هست و list comp
چیزی نیست جز یک تابع؛ برای همین اونهایی که فکر میکنند این رفتار عجیب یا اشتباه هست مشخصا نحوه عملکرد و جزئیات پایتون رو نمیشناسند.@pyHints
👍30🤯13🌚4✍2😐1
چطوری میشه یک شرکت، استارتاپ یا ... رو نابود کرد !؟
موضوع بر میگرده به ۳ سال پیش، یک شرکت (داخلی) برای همکاری به تیم ما پیشنهاد داد و یک مبلغی اعلام شد بعد از چندروز البته اعلام کرد که دستمزد ما ۲ برابر یک شرکت دیگه بوده و به همین دلیل با اون شرکت همکاری میکنند (نه تیم ما، یک دلیل هم همین بود که اونها شرکت ثبت شده هستند و ما یک تیم)
بگذریم، زمانبندی پروژه ۶ ماه عقب افتاد و بعد بالاخره پروژه لانچ شد (اینهارو میدونم چون یکی از دوستانم توی شرکت co-founder بود)
دقیقاً وقتی شرکت به اوج درآمد خودش رسیده بود و قرار بود این پروژه درآمد رو حداقل ۳ برابر کنه پروژه لانچ شد، اما ۱ سال بعد نه تنها درآمد ۳ برابر نشده بود بلکه بدهی پروژه مبلغی حدوداً ۱ میلیاردی بود (برای یک استارتاپ مبلغ خیلی زیادی بود) ۱ سال پول و وقت و ... چندین سال توسعه پروژه در نهایت ۱ میلیارد کسری بودجه با وجود فروش چند ده میلیاردی ؟ چطور ممکن هست ؟
۱- وقتی کار رو میدید دست نیرویی که با پول واقعی پروژه نزده اینطوری میشه.
۲- وقتی کار رو به تیمی میدید که زبان برنامهنویسی رو بخوبی نمیشناسه اینطوری میشه.
۳- وقتی نیرو کار رو از روی چندتا دوره آموزشی یاد میگیره اینطوری میشه.
اینها اولین صحبت من با دوستم قبل از code review بود چون بعد از توضیح منطق بیزینس ۹۹٪ میدونستم مشکل چی هست :
حالا مشکل چی بود:
یک اصطلاحی داریم به اسم
Banker's Rounding
مشکلی هست که با رند کردن اعداد به وجود میاد، اگر درست انجام بشه میانگین رند کردن سود هست برای صاحب بیزینس و اگر اشتباه باشه کاملاً ضرر مالی میشه
یک بخشی از قضیه این موضوع بود و بخش دوم که من توی ۹۰٪
Code Review
هایی که برای استارتاپها انجام میدم میبینم استفاده از نوع داده
Float
هست، اگر قرار به تمرین باشه این نوع داده خیلی هم خوبه ولی وقتی پای پول واقعی وسط هست اگر نمیخواهید کسی رو بدبخت کنید از
Decimal
استفاده کنید.
Decimal
هر ۲ مشکل شمارو حل میکنه، بخصوص مشکل False بودن عبارت زیر :
برای نسل جدید : هیچکس با یک دوره آموزشی برنامهنویس نمیشه، زیاد به دورهها تکیه نکنید.
@PyHints
موضوع بر میگرده به ۳ سال پیش، یک شرکت (داخلی) برای همکاری به تیم ما پیشنهاد داد و یک مبلغی اعلام شد بعد از چندروز البته اعلام کرد که دستمزد ما ۲ برابر یک شرکت دیگه بوده و به همین دلیل با اون شرکت همکاری میکنند (نه تیم ما، یک دلیل هم همین بود که اونها شرکت ثبت شده هستند و ما یک تیم)
بگذریم، زمانبندی پروژه ۶ ماه عقب افتاد و بعد بالاخره پروژه لانچ شد (اینهارو میدونم چون یکی از دوستانم توی شرکت co-founder بود)
دقیقاً وقتی شرکت به اوج درآمد خودش رسیده بود و قرار بود این پروژه درآمد رو حداقل ۳ برابر کنه پروژه لانچ شد، اما ۱ سال بعد نه تنها درآمد ۳ برابر نشده بود بلکه بدهی پروژه مبلغی حدوداً ۱ میلیاردی بود (برای یک استارتاپ مبلغ خیلی زیادی بود) ۱ سال پول و وقت و ... چندین سال توسعه پروژه در نهایت ۱ میلیارد کسری بودجه با وجود فروش چند ده میلیاردی ؟ چطور ممکن هست ؟
۱- وقتی کار رو میدید دست نیرویی که با پول واقعی پروژه نزده اینطوری میشه.
۲- وقتی کار رو به تیمی میدید که زبان برنامهنویسی رو بخوبی نمیشناسه اینطوری میشه.
۳- وقتی نیرو کار رو از روی چندتا دوره آموزشی یاد میگیره اینطوری میشه.
اینها اولین صحبت من با دوستم قبل از code review بود چون بعد از توضیح منطق بیزینس ۹۹٪ میدونستم مشکل چی هست :
حالا مشکل چی بود:
یک اصطلاحی داریم به اسم
Banker's Rounding
مشکلی هست که با رند کردن اعداد به وجود میاد، اگر درست انجام بشه میانگین رند کردن سود هست برای صاحب بیزینس و اگر اشتباه باشه کاملاً ضرر مالی میشه
یک بخشی از قضیه این موضوع بود و بخش دوم که من توی ۹۰٪
Code Review
هایی که برای استارتاپها انجام میدم میبینم استفاده از نوع داده
Float
هست، اگر قرار به تمرین باشه این نوع داده خیلی هم خوبه ولی وقتی پای پول واقعی وسط هست اگر نمیخواهید کسی رو بدبخت کنید از
Decimal
استفاده کنید.
Decimal
هر ۲ مشکل شمارو حل میکنه، بخصوص مشکل False بودن عبارت زیر :
0.3 == 0.1 + 0.1 + 0.1
برای نسل جدید : هیچکس با یک دوره آموزشی برنامهنویس نمیشه، زیاد به دورهها تکیه نکنید.
@PyHints
👍58🆒4❤3🤔2❤🔥1👾1
Python Hints
ولی باگ دوم که من حتی توی سورس کد فریمورکها و کتابخانههای معروف پایتون هم زیاد دیدم به راحتی میتونه توی مصاحبههای اولیه اوضاع رو بر علیه شما بکنه مشکل باز هم توی این خط هست : return f"Person(name={self.name!r}, age={self.age!r})" اگر دقت کنید اسم کلاس…
یکی دیگه از مزایای استفاده از
پیاده سازی شده استفاده کنه و به درستی هم نمایش بده
بازم اشاره میکنم که لاین ۸ از
@PyHints
type(self).__name__
موقع fall-back و inheritance هست با وجود اینکه کلاس Student
متد __repr__
براش پیاده سازی نشده (لازمم نداره اینجا) اما میتونه از آنچه که برای Person
پیاده سازی شده استفاده کنه و به درستی هم نمایش بده
بازم اشاره میکنم که لاین ۸ از
...
استفاده شده که اینجا کار همون pass
رو انجام میده.@PyHints
👍24
قبلا راجب cache نوشتن برای پروژههایی با محاسبات سنگین صحبت کردم
البته توی یک کانال دیگه :
https://t.iss.one/pytens/1018
دوستانی که کد تصویر رو متوجه نشدند شاید بهتره اون پیامهارو هم بخونند.
اینجا میخوام راجب دلیلی صحبت کنم که شما توی مصاحبه midlevel قبول میشی اما در طول یا بعد از قرارداد ۳ ماهه ارزیابی یا باهات خداحافظی میشه یا اینکه بهتون پیشنهاد دستمزد و کار junior داده میشه
(البته فقط بحث فنی)
@PyHints
البته توی یک کانال دیگه :
https://t.iss.one/pytens/1018
دوستانی که کد تصویر رو متوجه نشدند شاید بهتره اون پیامهارو هم بخونند.
اینجا میخوام راجب دلیلی صحبت کنم که شما توی مصاحبه midlevel قبول میشی اما در طول یا بعد از قرارداد ۳ ماهه ارزیابی یا باهات خداحافظی میشه یا اینکه بهتون پیشنهاد دستمزد و کار junior داده میشه
(البته فقط بحث فنی)
@PyHints
👍15✍3
Python Hints
قبلا راجب cache نوشتن برای پروژههایی با محاسبات سنگین صحبت کردم البته توی یک کانال دیگه : https://t.iss.one/pytens/1018 دوستانی که کد تصویر رو متوجه نشدند شاید بهتره اون پیامهارو هم بخونند. اینجا میخوام راجب دلیلی صحبت کنم که شما توی مصاحبه midlevel قبول میشی…
در ابتدا
توی سورس کد از dict استفاده میکنه پس ازین نظر فرقی با
نداره اما چرا پس
تعریف شده ؟
فرض کنید خروجی محاسبات چندین گیگابایت باشه، اگر محدودیت نداشته باشه مثل
رم رو پر میکنه و کد رو از کار میندازه، ولی این اتفاق توی
@lru_cache
توی سورس کد از dict استفاده میکنه پس ازین نظر فرقی با
cache = {}
نداره اما چرا پس
@lru_cache
تعریف شده ؟
maxsize
بهترین دلیلش هست اگر تعریف بشه Ram با نتایج کش شده پر نمیشه فرض کنید خروجی محاسبات چندین گیگابایت باشه، اگر محدودیت نداشته باشه مثل
cache = {}
رم رو پر میکنه و کد رو از کار میندازه، ولی این اتفاق توی
lru_cache
نمیافته👍16❤1✍1
Python Hints
قبلا راجب cache نوشتن برای پروژههایی با محاسبات سنگین صحبت کردم البته توی یک کانال دیگه : https://t.iss.one/pytens/1018 دوستانی که کد تصویر رو متوجه نشدند شاید بهتره اون پیامهارو هم بخونند. اینجا میخوام راجب دلیلی صحبت کنم که شما توی مصاحبه midlevel قبول میشی…
اما بحث اصلاً راجب
نبود و از فرصت استفاده کردم و توضیح دادم.
اما مسئله بحث چی بود، استفاده از cache فقط برای مصاحبه نیست
crawler
موقعیت خیلی مناسبی هست، دوستان زیادی در جریان برخی از کرالرهای نوشته شده بنده هستند بخصوص مواردی که نیاز به محاسبات پردازشی و درخواست به لینکهای تو در تو داره
درصد زیادی که کرالرهای بنده بلاک نمیشه یا توی معروفترین موارد تا بیش از ۱۰۰ گیگ دیتای سایتهای داخلی رو کرال کردم
استفاده از cache هست، یا حتی بهتر استفاده از ابزارهای دیگه که url های کرال شده دوباره براشون درخواست فرستاده نشه.
نکته دیگه راجب
که فراموش کردم بگم اگر argument های تابع رو جابجا بفرستید، دوباره محاسبات رو انجام میده پس به این نکته توجه کنید ینی :
و
۲ بار محاسبه میشه
@lru_cache
, ... نبود و از فرصت استفاده کردم و توضیح دادم.
اما مسئله بحث چی بود، استفاده از cache فقط برای مصاحبه نیست
crawler
موقعیت خیلی مناسبی هست، دوستان زیادی در جریان برخی از کرالرهای نوشته شده بنده هستند بخصوص مواردی که نیاز به محاسبات پردازشی و درخواست به لینکهای تو در تو داره
درصد زیادی که کرالرهای بنده بلاک نمیشه یا توی معروفترین موارد تا بیش از ۱۰۰ گیگ دیتای سایتهای داخلی رو کرال کردم
استفاده از cache هست، یا حتی بهتر استفاده از ابزارهای دیگه که url های کرال شده دوباره براشون درخواست فرستاده نشه.
نکته دیگه راجب
@lru_cache
که فراموش کردم بگم اگر argument های تابع رو جابجا بفرستید، دوباره محاسبات رو انجام میده پس به این نکته توجه کنید ینی :
add(a=1, b=2)
و
add(b=2, a=1)
۲ بار محاسبه میشه
👍20❤5✍1
__slots__
ازون مواردی هست که ممکنه ۲۰ سال توسعه دهنده پایتون باشید و هیچوقت استفاده نکنید ولی اگر توی شرایط درست و بجا استفاده کنید قطعا از کابوس نجاتتون میده
توضیحات پست بعدی
@PyHints
👍11⚡2🦄2
Python Hints
__slots__ ازون مواردی هست که ممکنه ۲۰ سال توسعه دهنده پایتون باشید و هیچوقت استفاده نکنید ولی اگر توی شرایط درست و بجا استفاده کنید قطعا از کابوس نجاتتون میده توضیحات پست بعدی @PyHints
اول از بزرگترین عیب استفاده از
همین رفتار اولین کاری که
پس مزیتهاش بدست میاد :
۱- سرعت بالاتری داره (توی پایتون ۳.۵ تا ۳۰٪ سریعتر میکرد دسترسی به attribute هارو)
۲- حافظه خیلی کمتری استفاده میکنه
چون شما دقیقا بهش میگید چه attribute هایی دارید و دیگه
حالا کجاها استفاده میشه ؟
چندتا مورد من بیشتر از همه دیدم :
مواقعی که از کلاسی که نوشتید ممکنه هزاران یا بیشتر
حالت دوم :
__slots__
بگم؛ و اونم از دست رفتن monkey patching
هست؛ خط ۲۱ کد رو نگاه کنید توی حالت معمول اگر یک instance از کلاسی بدون __slots__
داشتیم هیچوقت به ارور نمیخورد و education تبدیل میشد به یک instance attribute
و روی p مینشست.همین رفتار اولین کاری که
__slots__
میکنه رو لو میده حذف __dict__
از کلاس علاوه بر اون __weakref__
رو هم بیخیال میشه پس مزیتهاش بدست میاد :
۱- سرعت بالاتری داره (توی پایتون ۳.۵ تا ۳۰٪ سریعتر میکرد دسترسی به attribute هارو)
۲- حافظه خیلی کمتری استفاده میکنه
چون شما دقیقا بهش میگید چه attribute هایی دارید و دیگه
dynamic
نیستید؛ سربار دیکشنری توی پایتون بسیار زیاد هست.حالا کجاها استفاده میشه ؟
چندتا مورد من بیشتر از همه دیدم :
مواقعی که از کلاسی که نوشتید ممکنه هزاران یا بیشتر
instance
ساخته بشه و نیازی هم به monkey patch ندارید (بازیهای آنلاین - اکانتهای آنلاین و ...)حالت دوم :
ABC class
اما اگر توی این ۲ حالت نیستید و محدودیت حافظه براتون پیش نمیاد نباید رفت سراغش👍22⚡3☃2🔥2
Python Hints
بنظر شما توی این کد خروجی خط ۲۱ چی هست ؟ آیا میتونید راجب این رفتار توضیح هم بدید ؟ بحثی داشتم با یکی از دوستان راجب این مطلب که یاد مصاحبه مرحله دوم برای آمازون افتادم موضوع مربوط میشه به ۳-۴ سال پیش. سطح upper mid-level, senior python
همونطوری که احتمالا حدس زدید؛ خروجی خط ۲۱ :
@PyHints
هست.
اما توضیحاتش مهمتر از اینه که بگید خروجی چی هست :
توی پایتون یک موضوعی داریم به اسم
حالا چرا
توی پایتون یک موضوع دیگری هم وجود داره به اسم
پروتوکل
کلاسی در پایتون که شامل
پایتون هم که باشعور وقتی متوجه میشه از پروتوکل
@PyHints
هست.
@PyHints
هست.
اما توضیحاتش مهمتر از اینه که بگید خروجی چی هست :
توی پایتون یک موضوعی داریم به اسم
variable shadowing
اتفاقی که میوفته اینه که توی کد بالا به این موضوعی احترامی گذاشته نمیشه اگر name
توی کد بالا یک property
نبود قطعا متنی که توی خط ۱۹ بهش داده بودیم رو چاپ میکرد؛ حالا چرا
property
باعث شده که به variable shadowing
احترام گذاشته نشه توی پایتون یک موضوع دیگری هم وجود داره به اسم
Descriptor
که خودش ۲ مدل داره و توی کد بالا ما از data descriptor
داریم استفاده میکنیم وقتی شما از property
استفاده میکنید چه به صورت تابع چه بصورت decorator
اون property
در نهایت به صورت data descriptor
تعریف میشه پروتوکل
data descriptor
به این صورت تعریف میشه:کلاسی در پایتون که شامل
dunder method
های :__get__ and __set__ or __delete__
باشه که توی property
هر ۳ مورد وجود داره پایتون هم که باشعور وقتی متوجه میشه از پروتوکل
data descriptor
استفاده شده دیگه از __dict__
موجود برای instance
اطلاعات نمیگیره بلکه __get__
اون data descriptor
رو صدا میزنه به همین دلیل هم خروجی کد بالا @PyHints
هست.
👍18🤓4
این یکی ساده هست ولی خیلی مهم :
argument
ثابت صدا بزنید حتما از
هم تمیزتر هست هم کد رو خواناتر میکنه
@PyHints
from functools import partial
اگر قرار هست تابعی از فریمورک مورد نظرتون رو همیشه با چندتا argument
ثابت صدا بزنید حتما از
partial
استفاده کنید.هم تمیزتر هست هم کد رو خواناتر میکنه
Don't Repeat Yourselfهم که رعایت میشه اگر قرار باشه اون تابع رو بسیار استفاده کنید؛ دیگه لازم نیست آرگومانهای ثابت رو هی براش ارسال کنید
@PyHints
👍30🔥5👏1
بحث راجب
هدف اصلی :
پ.ن : توی مثال بالا مثلا اگر خواستید ی تابع برای
functools, partial
کامل نمیشه مگر با صحبت راجب singledispatch
ی decorator
خیلی عالی و قوی بجای if-else
های تو در تو برای چک کردن type
دادههدف اصلی :
Clean code
فقط نکته مهم این هست که singledispatch
با آرگومان اول ورودی تابع کار میکنه فقطپ.ن : توی مثال بالا مثلا اگر خواستید ی تابع برای
int, floatاضافه کنید که هر ۲ رو پشتیبانی کنه در این حالت نیاز دارید از
Union
و Typing
هم استفاده کنید:from typing import Union
@PyHints👍19❤🔥2
تا داریم از
کارش اینه من یک کلاس کاستوم میسازم و میخوام بین آبجکت های کلاسم مقایسه رو پشتیبانی کنم
اما ازونجایی که حال ندارم همهی موارد مقایسه رو بنویسم :
توصیه مهمی هست که حتما
باقی عملگرها به لطف
@PyHints
functools
صحبت میکنیم بیاید و اجازه بدید راجب total_ordering
هم صحبت کنیم :کارش اینه من یک کلاس کاستوم میسازم و میخوام بین آبجکت های کلاسم مقایسه رو پشتیبانی کنم
اما ازونجایی که حال ندارم همهی موارد مقایسه رو بنویسم :
__lt__, __le__, __gt__, __ge__, ....میام یکی ازین موارد رو پیاده سازی میکنم و در کنارش هم
__eq__
رو پیاده سازی میکنم. توصیه مهمی هست که حتما
__eq__
پیادهسازی بشه وگرنه باگ مخفی میخوریدباقی عملگرها به لطف
@total_ordering
بصورت خودکار برای کلاس مدنظرم پیاده سازی میشه @PyHints
👍20❤🔥3
Python Hints
تا داریم از functools صحبت میکنیم بیاید و اجازه بدید راجب total_ordering هم صحبت کنیم : کارش اینه من یک کلاس کاستوم میسازم و میخوام بین آبجکت های کلاسم مقایسه رو پشتیبانی کنم اما ازونجایی که حال ندارم همهی موارد مقایسه رو بنویسم : __lt__, __le__, __gt__…
اما توی این کد یک مورد bad practice خفن هم وجود داره :
پایتون بصورت خودکار کلاس و object اش روی برای ما hashable میکنه
راهکارش هم خیلی سادهاس فقط میاد آدرس حافظه اون instance ایی که از کلاس ساختیم رو میگیره و hash میکنه و بهمون بر میگردونه
اما این موضوع تا وقتی کار میکنه که :
پیاده سازی نشده باشه اضافه کنم
توی کد بالا وقتی من اومدم و
برای درک بهتر کد بهترین حالت این هست که از خط زیر استفاده کنید داخل کلاس :
و فکر نمیکنه شما فراموش کردید.
در نهایت به خط 10 هم توجه کنید؛ hardcode نکردم اسم کلاس رو بلکه از
@PyHints
پایتون بصورت خودکار کلاس و object اش روی برای ما hashable میکنه
راهکارش هم خیلی سادهاس فقط میاد آدرس حافظه اون instance ایی که از کلاس ساختیم رو میگیره و hash میکنه و بهمون بر میگردونه
اما این موضوع تا وقتی کار میکنه که :
__eq__()
پیاده سازی نشده باشه اضافه کنم
__eq__
برای ==
استفاده میشه توی کد بالا وقتی من اومدم و
__eq__
رو پیاده سازی کردم باید __hash__
رو هم پیاده سازی کنم بعنوان مثال :def __hash__(self):
return hash((self.name, self.grade))
حالا اگر به عمد نخواستیم instance هامون hashable باشه چی ؟برای درک بهتر کد بهترین حالت این هست که از خط زیر استفاده کنید داخل کلاس :
__hash__ = None
اینجوری یوزر یا هرکسی دیگه که کدهای شمارو بخونه درک میکنه که شما به عمد و بنا به دلایل طراحی instance های این کلاس رو hashable نکردید و فکر نمیکنه شما فراموش کردید.
در نهایت به خط 10 هم توجه کنید؛ hardcode نکردم اسم کلاس رو بلکه از
isinstance(other, type(self))که راجب اهمیتش توی پستهای قبلی و صحبت راجب
__repr__
گفتم.@PyHints
👍17
نحوه تعریف
اگر توی یک پروژه حرفهای مثل کد بالا
همیشه گفتم بازم میگم :
اگر میخوای از یک دولوپر انتقام بگیری یا بیچارهاش کنی فقط ی
مشکل کد چیه :
همهی متا دیتا مربوط به تابعی که
ولی برای
دیباگ کردن همچین کدی آدم رو دیوونه میکنه خروجی رو ببینید
راه حل : پست بعدی
@PyHints
decorator
میتونه نشون بده دولوپر پروژه junior هست یا نه اگر توی یک پروژه حرفهای مثل کد بالا
decorator
تعریف میکنید و بیش از ۳-۴ بار ازش استفاده میشه شما سیگنال junior developer
بودن میدی به کسی که کد رو میخونه.همیشه گفتم بازم میگم :
اگر میخوای از یک دولوپر انتقام بگیری یا بیچارهاش کنی فقط ی
decorator
اینطوری بنویس و توی کل پروژه استفاده کن مشکل کد چیه :
همهی متا دیتا مربوط به تابعی که
decorate
شده مثل func1, func2
رو پاک میکنه و اطلاعات decorator
رو جاش مینوسته توی حالت معمول این اشتباه نیست و منطق درستی هست ولی برای
decorator
خیلی اشتباه داری میزنی.دیباگ کردن همچین کدی آدم رو دیوونه میکنه خروجی رو ببینید
name, docstring
تابع به wrapper
تغییر کرده راه حل : پست بعدی
@PyHints
👍20✍2🌚1
Python Hints
نحوه تعریف decorator میتونه نشون بده دولوپر پروژه junior هست یا نه اگر توی یک پروژه حرفهای مثل کد بالا decorator تعریف میکنید و بیش از ۳-۴ بار ازش استفاده میشه شما سیگنال junior developer بودن میدی به کسی که کد رو میخونه. همیشه گفتم بازم میگم : اگر…
راه حل :
خروجی رو اگر دقت کنید docstrign, name تابع به درستی نشون داده شده و debug , .... برای دولوپر بعدی قطعا به مراتب راحت تر خواهد بود.
این ۲ خط تغییر (خط ۱ و ۵) خیلی زندگیها نجات داده و آدمای بزرگی بعد از دیدن این ۲ خط توی کد امید به زندگیشون بالا رفته و دست از خودکشی کشیدن
اگر
@PyHints
functools
مقدس؛ این آخرین پست درباره functools
هست همه موارد مهم این ماژول صحبت شدfrom functools import wraps
به لطف دکوریتور wraps
به پایتون میگیم که meta data
مربوط به تابع اصلی رو نگه داره و اطلاعات تابع wrapper
رو روی اون بازنویسی نکنهخروجی رو اگر دقت کنید docstrign, name تابع به درستی نشون داده شده و debug , .... برای دولوپر بعدی قطعا به مراتب راحت تر خواهد بود.
این ۲ خط تغییر (خط ۱ و ۵) خیلی زندگیها نجات داده و آدمای بزرگی بعد از دیدن این ۲ خط توی کد امید به زندگیشون بالا رفته و دست از خودکشی کشیدن
اگر
decorator
نوشتی تورو خدا این ۲ خط رو اضافه کن (شاید ۱ زندگی رو نجات دادی) @PyHints
👌21👍5❤1✍1⚡1