نوشته‌های ترمینالی
2.62K subscribers
424 photos
12 videos
32 files
2.25K links
Download Telegram
تابع range تو پایتون چی برمیگردونه؟
لیست؟ نه
توپل؟ بازم نه.
آیا خروجی قابل iterate هست؟ بله.

اگه دوست دارید فرق iterable و iterator رو توی پایتون بدونید این مطلب توصیه میشه.

https://treyhunner.com/2018/02/python-range-is-not-an-iterator/

پی‌نوشت: اگرچه ما به عنوان تابع استفاده می‌کنیم، ولی به شکل دقیق تر یه کلاس محسوب میشه.
https://docs.python.org/3/library/functions.html#func-range
👍81
Forwarded from Aryan
سلام بچه ها امیدوارم حالتون خوب باشه
من چند روز پیش پروژه «هزار» رو که نزدیک یک سال پیش شروع کردم توی لینکدین معرفی کردم.
به طور خلاصه هزار بزرگترین پروژه هوش مصنوعی اوپن سورس برای زبان فارسیه که شامل مدل های مختلفی برای پردازش متن، صوت و تصویر میشه و برای وظایف مختلفی از جمله
speech recognition، OCR، image captioning، language modeling، text generation، text classification, sequence labeling, word embedding, ...
مدل آماده داره و همواره در حال توسعه مدل های جدیدتر هستیم.
برای اطلاعات بیشتر شدیدا پیشنهاد می کنم پست لینکدین رو ببینید یا گیت هاب پروژه رو بخونید.

برای این پروژه پلن های بلندمدتی داریم و به مرور داریم تیم توسعه رو گسترش میدیم.
اگر به این حوزه ها علاقه دارید و خیلی دست به کد هستید (سابقه عمیق علمی و عملی در زمینه های مختلف هوش مصنوعی) میتونید بهمون خبر بدید.
اگر از این کار خوشتون اومد و دوست دارید حمایت کنید حتما روی گیت هاب استار بدید.
هر سوال و پیشنهادی هم دارید میتونید مستقیما به خودم (@arxyzan) پیام بدید.
👍5
شاید شنیده باشید که curl یه باگ خطرناک داشته.
جریان از این قراره که وقتی که از socks5h استفاده می‌کردید، به شکل پیشفرض می‌اومده و گرفتن کوئری dns رو از سرور پروکسی انجام می‌داده، اما طبق پروتوکل، تا یه طول محدودی می‌شه نام دامنه رو فرستاد سمت سرور socks که برامون از dns بپرسه.
خلاصه برای هندل کردن حالتی که طول دامنه بلند باشه به buffer overflow میخورده.

این بلاگ اطلاعات خوبی از دو تا آسیب پذیری و چیزایی که تحت تاثیر قرار میدن نوشته. خلاصه اینکه نسخه‌ی ۸.۴.۰ به بعد رو نصب کنید و تا ۸.۳.۰ آسیب پذیر هستن. اگرم نه از socks5 بدون h استفاده کنید که کلا از dns لوکال استفاده می‌کنه.

https://jfrog.com/blog/curl-libcurl-october-2023-vulns-all-you-need-to-know/

این بلاگ پست هم مال خود برنامه‌نویسشه که فنی‌تر گفته و البته کوتاه تره، خیلی توصیه می‌کنم بخونید حتی اگر کاربر curl نیستید.
https://daniel.haxx.se/blog/2023/10/11/how-i-made-a-heap-overflow-in-curl/


توصیه‌ی آخر هم اینکه مراقب مشکلات مموری باشید، اگه دقت کنید اکثر CVEها که میاد (همون آسیب پذیری ها) به خاطر مشکلات حافظه‌ی برنامه‌های سی و سی پلاس پلاسه.
👍5🔥2
Forwarded from Things that I like (Maedeh Dehghan)
یه سایت کاربردی برای کارهای مختلف:
https://tinywow.com/
👍5
Forwarded from Programming Resources via @like
Build famous projects from scratch with a huge and friendly community to increase your knowledge about software engineering and its challenges.
پروژه های معروف را از ابتدا با یک جامعه بزرگ و دوستانه بسازید تا دانش خود را در مورد مهندسی نرم افزار و چالش های آن افزایش دهید.

#practice #programming #code #scratch #applpication #server #basic #interview
@pythony

https://app.codecrafters.io
2👍2
تفاوت database با data warehouse با data lake چیه؟
تو بلاگ mongo db بخونید.

https://www.mongodb.com/databases/data-lake-vs-data-warehouse-vs-database
👍3
Forwarded from LinFAQ (Reza)
#روزی_یک_نکته با دلاتو

دسته‌بندی: #کاربردی #آموزشی

برا داشتن لیست ابزار های نصب شده داخل پکمن:
کاری که انجام دادم این بود که لیست کل پکیج های نصب شده رو داخل یه فایل نگه داشتم (هر خط اسم یه پکیج)، مثلا توی مسیر زیر:

/home/user/packages.txt

خب حالا هر بار میخوام سیستم رو بروز کنم یا پکیجی رو نصب کنم از دستور زیر استفاده میکنم (که میشه براش یه alias ردیف کرد):

sudo pacman -Syu --needed - < /home/user/packages.txt

(چون sudo اولش هست اگه ~ استفاده کنم تو home یوزرم دنبال فایله نمیگرده...
برای همین مسیر کامل دادم، هنوز تست نکردم
$HOME
جواب هست یا نه)، که خب لیست فایل رو میگیره و اگه نصب نبودن همزمان با بروز کردن سیستم اون هارو هم نصب میکنه
(فلگ needed-- برا اینه که اگه از قبل اون پکیج ها نصب و بروز بودن دوباره نصبشون نکنه).
میتونید یه alias ردیف کنید براش:

alias update='sudo pacman -Syu --needed - < /home/user/packages.txt'

اینطوری برا نصب پکیج، کافیه اسم پکیج رو به اون فایل اضافه کنید و بعد update رو اجرا کنید.

برا لیست کردن پکیج های نصب شده میشه از دستور زیر استفاده کرد:

pacman -Qqe > pkglist.txt

منبع: https://wiki.archlinux.org/title/pacman/Tips_and_tricks#List_of_installed_packages

ضمنا منبع بالا برای بروز کردن لیست پکیج های نصب شده روی سیستم بعد هر بار نصب و حذف پکیج هم راه حل داده.

اگه بخواید بر اساس اون لیست کل پکیج ها حذف/ نصب بشن (هر پکیجی که تو لیست نبود ولی نصب بود حذف بشه و هر پکیجی که تو لیست بود ولی نصب نبود نصب بشه) میشه از این بخش ویکی کمک گرفت:


در نهایت این شیوه ها برای نصب دوباره پکیج ها روی سیستم جدید و به صورت کلی مدیریتشون کمک میکنه.
🔅@LinFAQ
🔅@LinAcademy
👍5👎1
تیپیکال سوال مصاحبه: وقتی google[dot]com رو توی مرورگر می‌زنیم چه اتفاقی می‌افته؟
این سوال می‌تونه بر اساس دانش شما از جنبه های مختلفی مثل شبکه (شامل DNS و TCP و routing) تا مرورگر (مثل پردازش ورودی و DOM و render کردن) یا بک‌اند (مثل وب سرورها و نحوه تولید دیتا در کنار فایروال و لود بالانسر و api gateway و ...) پاسخ داده بشه.

این پیج گیتهاب پاسخ نسبتا خوبی به این سوال داده و از زمینه های مختلفی مثل سخت افزار و مرورگر و شبکه بهش پرداخته ولی خیلی به بک‌اند نپرداخته به نظرم.
در کل هم عمقش کمه و طولش به نسبت طولانی نیست و اگر خیلی دانش تخصصی زیادی ندارید هم میتونید با گذر از بخش هایی که متوجه نمیشید، ازش لذت ببرید.

https://github.com/alex/what-happens-when
👍9
چرا self-study بد است؟
https://www.youtube.com/watch?v=g7MSfHEdxXs


ایده این ویدیو این نیست که self study نکنیم، بلکه میگه این خطرات رو داره و اگر مثلا در روندش احساس حماقت کردید یا انگیزه‌تون رو از دست دادید مشکل شما نیست، مشکل این روشه.
👍10👎1
چرا نوشتن فایل‌ها در tmpfs بد است!
https://rwmj.wordpress.com/2012/09/12/tmpfs-considered-harmful/

این مقاله کوتاه توضیح میده که چطوری میتونه ما به عنوان کاربر و برنامه‌نویس رو گمراه کنه و باعث بشه فایل‌های مهممون پاک بشن.

همچنین می‌تونید نظرات کاربرا رو اینجا بخونید:
https://news.ycombinator.com/item?id=4510171


پانوشت: tmpfs یه مدل فایل‌سیستم موقته که در خیلی از توزیع‌ها توی /tmp ازش استفاده می‌شه و فایل‌ها رو فقط در زمان روشن بودن سیستم حفظ می‌کنه (مثل مموری)
👍4
اگه به کانکارنسی علاقه دارید این مطلب رو حتما توصیه می‌کنم بخونید:
در مورد روش های مختلف concurrency control مثل لاک‌ها
https://concurrencyfreaks.blogspot.com/2023/09/50-years-later-is-two-phase-locking.html
👍2
اگه مک دارید و می‌خواید با caps-lock زبون رو عوض کنید، در حالت عادی گاهی کار می‌کنه و گاهی نمی‌کنه.
اینجا یه راه حل خوب براش هست:
https://apple.stackexchange.com/a/456649
👍31
اگه تو مک می‌خواید markdown بنویسید، اکثر ادیتورهای خوب پولی هستن متاسفانه من از typora تو لینوکس استفاده می‌کردم که اینجا پولیه.

اینجا یه لیست از ابزارهای متن‌باز ادیت مارک‌داون هست:
https://github.com/marktext/marktext

چند تا گزینه‌ی خوب با پشتیبانی نسبتا خوب از فارسی marktext و zettlr هستن. البته دومی گزینه‌های بیشتری هم داره.

جمع‌بندی من استفاده از marktext بود با چند تا نکته:
اول که نصبش می‌کنید چون اکانت دولوپر اپل ندارن و ساینش نکردن، برنامه باز نمیشه. این دستور رو بزنید بهش اعتماد میکنه و باز میشه:

xattr -cr /Applications/MarkText.app



برای فارسی نوشتن مشکلی نیست و می‌تونید حالت RTLش رو فعال کنید ولی برای خروجی گرفتن، کار خودشو می‌کنه. در واقع بر اساس تم‌هاش خروجی رو تولید می‌کنه که تم ‌های پیش‌فرضش پشتیبانی نمی‌کنن از متن راست به چپ. برای همین می‌تونید یه تم بسازید که این مشکل رو حل کنه:


/** ME **/

.markdown-body {
direction: rtl;
}

pre {
direction: ltr;
}



کافیه متن بالا (کامنتش هم مهمه) رو تو یه فایل در مسیر تم‌ها بذارید.

لینوکس:

~/.config/marktext/themes/export/my-theme.css


مک:


~/Library/Application Support/marktext/themes/export/my-theme.css
👍1
اگر macتون fingerprint داره، می‌تونید به‌جای تایپ کردن رمز سودو ازش استفاده کنید.
چطوری؟ یه فایل رو باید با دسترسی روت ادیت کنید و یه خط بهش اضافه کنید.
جزئیاتش رو اینجا ببینید:
https://apple.stackexchange.com/questions/259093/can-touch-id-on-mac-authenticate-sudo-in-terminal
🤯3
اگر خواسته باشید رو مک، صدای سیستم رو ضبط کنید مثلا برای ضبط کلاس انلاین، حتما با چالش‌هاش مواجه شدین. چالش‌ها در این حده که یه ماژول به کرنل اضافه کنید و ...
خبر خوب اینه که از نسخه ی ۱۳ به بعد بدون دردسر صدای یه برنامه یا کل سیستم رو بگیرید و ضبط کنید. مثلا این آموزش obs ئه.
نکته‌ای که باید دقت کنید اینه که از macOs screen capture به جای حالت عادی استفاده کنید.

https://obsproject.com/kb/macos-desktop-audio-capture-guide
اگه mac m1 دارید احتمالا مشکلات زیادی هم با معماری پردازنده‌ش داشتید. البته من طرفدار بروز شدن معماری‌ها هستم و به نظرم خیلی قدم مهمی بود.

چند تا مشکلی که داشتم اینا هستن:
ابزار proxychains که قبلا هم در موردش صحبت کردم، اینطوری کار میکرد که لایبرری‌های برنامه‌ی مورد نظر رو دستکاری میکرد تا به جای اینکه ترافیک شبکه رو مستقیم بفرستن بیرون، از یه socksای چیزی رد کنن.
حالا این دستکاری لایبرری‌ها قاعدتا مشکلاتی داره.
مشکلی که اینجا هست اینه که گویا تو نسخه ۱۴ یه باگ ریزی هم وجود داره که خود سیستم معماری پردازنده رو درست مشخص نمی‌کنه.
به هر حال در موردش اینجا بخونید. ایشو هنوز بازه ولی راه‌هایی شامل کامپایل از سورس پیشنهاد دادن.
راه جایگزین هم البته استفاده از environment variableها هستن.


راستی یادمون نره که دستکاری لایبرری‌ها تو این سیستم‌عامل به شکل پیشفرض ممنوعه. مکانیسمی که وجود داره اسمش SIP یا system integrity protection هست. برای غیرفعال کردنش هم باید برید تو مود ریکاوری (که تو مکبوکهای جدید با مکبوکهای قدیمی فرق داره روشش و اصلا سرراست نیست خلاصه)
و این دستور رو بزنید:


csrutil disable
داکر هم با توجه به ماهیتش سخته که بخواد با کرنلی غیر از لینوکس کار کنه، حالا معماری هم متفاوت باشه که دیگه واویلا.

حالا اگر docker desktop رو نصب کنید خیلی خوب پیش‌نیازها هندل شده و out of the box کار می کنه، فقط محدودیتش اینه که باید تو پس زمینه اجرا باشه تا دستورای داکر کار کنه یعنی daemonی نداره.
اما مشکلی که هست اینه که خیلی کنده. خیلی خیلی کند گاهی. مخصوصا برای کارهایی که شامل کار با فایل‌های زیاد و دسترسی به file system می‌شه ترجمه‌ی سیستم‌کال‌ها گویا خیلی طول می‌کشه!


این مطلب راه‌های خوبی پیشنهاد داده و خیلی کامله.
https://www.syntasso.io/post/slow-performance-on-m1-macbooks-leads-to-supporting-multi-architecture-docker-builds

این پروژه هم ببینید بد نیست:
https://github.com/abiosoft/colima
و این هم آموزش استفاده ازش:
https://opensource.com/article/22/9/docker-desktop-colima


همچنین کاری که خودم کردم این بود: می‌تونید به جای desktop-linux از بیلدر دیفالت استفاده کنید. با یه چنین دستوری:

docker context use default


اینکه داستان چیه رو اینجا بخونید:
https://stackoverflow.com/a/49688931

اینکه چرا کار میکنه رو دقیق نمی‌دونم ولی فکر کنم موقع پول کردن از داکرهاب پلتفرم رو هم مشخص می‌کنه و ایمج‌های مناسبی رو می‌گیره، اما اگر اون ایمج نسخه‌ی arm8 نداشته باشه (که اکثرا دیدم دارن) مشکل داریم و باید برگردیم به همون روش‌های قبلی.


ادیت:
دوستمون تو کامنت‌ها orb رو پیشنهاد کردن که فوق‌العاده چیز سریع و مرتبیه. حتما توصیه می‌کنم شما هم تست کنید.
https://orbstack.dev/
https://github.com/orbstack/orbstack
2