از طریق منوی جستجو مطلب مورد نظر خود در وبلاگ را به سرعت پیدا کنید
Vim برای توسعه پایتون
سرفصلهای مطلب
Vim چیست؟
Vim یک ویرایشگر متن قدرتمند است که به یکی از اجزای پیش فرض تعلق دارد روی هر توزیع لینوکس، و همچنین Mac OS X. Vim از مفهوم استفاده خود پیروی می کند و باعث می شود که جامعه به حامیان قوی و مخالفان سرسخت تقسیم شود که طرفدار ویرایشگرهای دیگری مانند Emacs هستند. (به هر حال، این در زمستان بسیار خوب است تا دو تیم مشتاق را در حال مبارزه گسترده با گلوله برفی با هم ببینیم).
Vim را می توان با استفاده از افزونه های اضافی به منظور تنظیم ابزار با نیازهای خاص شما، فردی و توسعه داد. در این مقاله، مجموعهای از برنامههای افزودنی را برجسته میکنیم و در مورد یک راهاندازی مفید برای بهبود توسعه نرمافزار با پایتون بحث میکنیم.
تکمیل خودکار
Vim قبلاً به ویژگی تکمیل خودکار مجهز شده است. این به خوبی کار می کند، اما محدود به کلماتی است که از قبل در بافر متن فعلی وجود دارند. در حالت درج، با استفاده از کلید ترکیبی CTRL+N
کلمه بعدی را در بافر فعلی دریافت می کنید، و CTRL+P
آخرین در هر صورت، منویی با کلمات ظاهر میشود که از میان آن، کلمهای را انتخاب میکنید که در متن در موقعیت مکاننمای فعلی سند جایگذاری شود.
این در حال حاضر بسیار جالب است. خوشبختانه، همین ویژگی برای تمام خطوط متن وجود دارد. در حالت درج فشار دهید CTRL+X
اول، به دنبال آن CTRL+L
. منویی با خطوط مشابه ظاهر میشود که از میان آن خطی را که میخواهید در متن در موقعیت مکاننمای فعلی سند جایگذاری شود، انتخاب میکنید.
برای توسعه موثر در پایتون، Vim شامل یک ماژول استاندارد به نام است پایتون کامل (پایتون Omni Completion). برای فعال سازی این افزونه دو خط زیر را به فایل پیکربندی Vim خود اضافه کنید .vimrc
:
filetype plugin روی
set omnifunc=syntaxcomplete#Complete
سپس، در پنجره ویرایشگر Vim، تکمیل بر اساس حالت درج کار می کند روی ترکیب کلید CTRL+X
به دنبال CTRL+O
. یک منوی فرعی ظاهر می شود که توابع و کلمات کلیدی پایتون را برای استفاده به شما ارائه می دهد. ورودی های منو بر اساس هستند روی توضیحات ماژول پایتون (“رشته اسناد”). مثال زیر نشان می دهد abs()
عملکرد با کمک اضافی روی بالای صفحه ویرایشگر vim.
افزونه بعدی که می خواهم در مورد آن صحبت کنم نام دارد جدی-ویم. Vim را با جدی کتابخانه تکمیل خودکار
با نصب بسته مطابقت روی دبیان شما GNU/سیستم لینوکس به یک مرحله اضافی برای کارکردن Jedi-Vim نیاز دارد. این افزونه باید با استفاده از مدیر پلاگین Vim به صورت زیر فعال شود:
$ vim-addons install python-jedi
Info: installing removed addon 'python-jedi' to /home/frank/.vim
Info: Rebuilding tags since documentation has been modified ...
Processing /home/frank/.vim/doc/
Info: done.
در مرحله بعد، وضعیت افزونه را بررسی کنید:
$ vim-addons status python-jedi
python-jedi installed removed
اکنون افزونه فعال شده است و می توانید در حین برنامه نویسی از آن در Vim استفاده کنید. به محض اینکه یک نقطه را تایپ کردید یا فشار دهید CTRL+Space
منو باز می شود و نام روش ها و اپراتورها را نشان می دهد که می توانند مناسب باشند. تصویر زیر ورودی های مطابق با آن را نشان می دهد csv
مدول. به محض اینکه یک مورد را از منو انتخاب کنید، در کد منبع شما قرار می گیرد.
یک افزونه تعاملی است تو کامل کن. خود را به عنوان “موتور تکمیل کد جستجوی فازی سریع، مطابق با نوع شما برای Vim” توصیف می کند. برای پایتون 2 و 3، تکمیل خودکار مبتنی است روی جدی هم همینطور در میان سایر زبان های برنامه نویسی، از C#، Go، Rust و Java نیز پشتیبانی می کند.
راه اندازی که در یک مخزن Git ارائه شده است، برای استفاده از آن به مراحل دیگری نیاز دارد. بسته روی دبیان GNU/لینوکس همراه با نسخه کامپایل شده و پس از نصب بسته از طریق apt-get
را مراحل زیر اراده آن را کار کند. ابتدا بسته را با استفاده از Vim-addon-manager فعال کنید (vam
) یا دستور vim-addons
:
$ vim-addons install youcompleteme
Info: installing removed addon 'youcompleteme' to /home/frank/.vim
Info: Rebuilding tags since documentation has been modified ...
Processing /home/frank/.vim/doc/
Info: done.
در مرحله بعد، وضعیت افزونه را بررسی کنید. خروجی زیر به شما نشان می دهد که این افزونه با موفقیت برای شما به عنوان یک کاربر معمولی نصب شده است:
$ vim-addons status youcompleteme
youcompleteme installed removed
سوم، پیش فرض را کپی کنید ycm_extra_conf.py
فایل از دایرکتوری نمونه ها به شما ~/.vim/
پوشه به صورت زیر
$ cp -v /usr/share/doc/vim-youcompleteme/examples/ycm_extra_conf.py .ycm_extra_conf.py
"/usr/share/doc/vim-youcompleteme/examples/ycm_extra_conf.py" -> ".ycm_extra_conf.py"
مرحله آخر این است که دو خط زیر را به خط خود اضافه کنید .vimrc
فایل:
" youcompleteme
let g:ycm_global_ycm_extra_conf = "~/.vim/.ycm_extra_conf.py"
خط اول یک نظر است که می تواند حذف شود و خط دوم فایل پیکربندی را برای youcompleteme
افزونه و voilà! – اکنون Vim تکمیل خودکار کد را می پذیرد. وقتی می بینید که یک رشته تکمیل مفید ارائه شده است، دکمه را فشار دهید TAB
کلید پذیرش آن این رشته تکمیل را در موقعیت فعلی درج می کند. فشارهای مکرر از TAB
چرخه کلید از طریق تکمیل های ارائه شده
برجسته سازی نحو
Vim در حال حاضر با برجسته سازی نحو برای تعداد زیادی از زبان های برنامه نویسی از جمله Python ارائه شده است. سه پلاگین وجود دارد که به بهبود آن کمک می کند – یکی نام دارد python-نحو، دیگری است python-حالت، و سومی است python.vim.
در میان دیگران python-سایت پروژه syntax تعداد زیادی بهبود مانند برجسته کردن استثناها، doctestها، خطاها و ثابت ها را فهرست می کند. یک ویژگی خوب، سوئیچ بین برجسته سازی نحو برای پایتون 2 و 3 مبتنی بر آن است روی یک دستور اضافی Vim – :Python2Syntax
و :Python3Syntax
. این به شناسایی تغییرات احتمالی که برای اجرای اسکریپت شما با هر دو نسخه لازم است کمک می کند.
ترکیب Vim با Revision Control System Git
کنترل بازبینی برای توسعه دهندگان کاملا ضروری است و Git احتمالا بهترین سیستم برای آن است. با کامپایل کردن کد پایتون، مفسر تعدادی فایل موقت مانند __pycache__
و *.pyc
. تغییرات این فایل ها نیازی به ردیابی در Git ندارند. برای نادیده گرفتن آنها Git ویژگی به اصطلاح ارائه می دهد .gitignore
فایل. این فایل را در شاخه توسعه مدیریت Git خود با محتوای زیر ایجاد کنید:
*.pyc
__pycache__
همچنین، یک را اضافه کنید README
فایلی را برای پروژه خود به ثبت برسانید تا در مورد آن مستند کنید. مهم نیست که پروژه شما چقدر کوچک است، README
فایل به شما (و سایرین) کمک می کند تا به خاطر بسپارید که کد برای انجام چه کاری قرار دارد. نوشتن این فایل با فرمت Markdown به ویژه در صورتی مفید است که کد پایتون خود را با مخزن خود همگام کنید. روی GitHub. این README
فایل به طور خودکار به HTML ارائه می شود که به راحتی در مرورگر وب شما قابل مشاهده است.
Vim می تواند مستقیماً با استفاده از افزونه های ویژه با Git همکاری کند. در میان دیگران وجود دارد vim-fugitive، gv.vim و vimagit. همه آنها از GitHub و بیشتر به عنوان یک بسته برای Debian در دسترس هستند GNU/لینوکس.
دانلود vim-fugitive از طریق apt-get
باید به روشی مشابه با سایر پلاگین ها فعال شود:
$ vim-addons install fugitive
Info: installing removed addon 'fugitive' to /home/frank/.vim
Info: Rebuilding tags since documentation has been modified ...
Processing /home/frank/.vim/doc/
Info: done
این افزونه فقط با فایل هایی کار می کند که با Git ردیابی می شوند. تعداد زیادی از دستورات اضافی Vim مانند :Gedit
، :Gdiff
، :Gstatus
، :Ggrep
و :Glog
. همانطور که بیان شد روی وب سایت پروژه، این دستورات Vim با دستورات و اقدامات Git زیر مطابقت دارد:
:Gedit
: فایلی را در ایندکس ویرایش کنید و روی آن بنویسید تا تغییرات را مرحله بندی کنید:Gread
(git checkout -- filename
): محتوای فایل را در بافر فعلی بارگذاری کنید:Gwrite
(git add
): فایل را به لیست فایل های ردیابی شده فعلی اضافه کنید:Gdiff
(git diff
): نسخه مرحلهای فایل را در کنار نسخه درخت کار بیاورید و از قابلیتهای مدیریت تفاوت Vim برای مرحلهبندی زیرمجموعهای از تغییرات فایل استفاده کنید.:Gmove
(git mv
): یک فایل را به مکان جدید منتقل کنید:Gstatus
(git status
): وضعیت فعلی دایرکتوری Git خود را نشان دهید:Gcommit
(git commit
): تغییرات خود را متعهد کنید:Ggrep
(git grep
): الگوی داده شده را در مخزن Git جستجو کنید:Glog
(git log
): تمام ویرایش های قبلی یک فایل را در لیست رفع سریع بارگذاری می کند تا بتوانید روی آنها تکرار کنید و تکامل فایل را تماشا کنید!:Gblame
(git blame
): نشان می دهد چه کسی آخرین تغییرات را در یک فایل انجام داده است
کار با اسکلت
فایلهای اسکلت (یا قالبها) یکی از ویژگیهای خوب Vim هستند که با افزودن متن پیشفرض به فایل هنگام ایجاد فایل جدید، بهرهوری شما را بهبود میبخشد. به عنوان مثال، در بسیاری از فایلهای پایتون شما باید a شبنگ، مجوز، رشته مستند و اطلاعات نویسنده در ابتدای فایل. تایپ کردن یا حتی کپی کردن این اطلاعات در هر فایل مشکل ساز خواهد بود. در عوض، می توانید از فایل های اسکلت برای اضافه کردن این متن پیش فرض برای خود استفاده کنید.
فرض کنید، برای مثال، میخواهید همه فایلهای پایتون جدید با متن زیر شروع شوند:
"""
(Add module documentation here)
Author: Frank
Date: (Add date here)
"""
شما یک فایل با این محتوا ایجاد می کنید و آن را چیزی شبیه به آن می نامید skeleton.py
و سپس آن را به دایرکتوری منتقل کنید ~/.vim/skeleton.py
. برای اینکه به Vim بگویید کدام فایل باید به عنوان فایل اسکلت پایتون استفاده شود، موارد زیر را به فایل خود اضافه کنید .vimrc
فایل:
au BufNewFile *.py 0r ~/.vim/skeleton.py
این به Vim میگوید که از فایل اسکلت مشخص شده برای همه فایلهای جدید مطابق با نام فایل استفاده کند *.py
.
یادداشت روی استفاده از افزونه ها
معمولا Vim بسیار سریع است. هر چه افزونه های بیشتری را فعال کنید، مدت زمان بیشتری طول می کشد. شروع Vim به تعویق افتاده است و به طور قابل توجهی بیشتر از قبل طول می کشد. همچنین، معمول است که بستههای Debian/Ubuntu خارج از جعبه کار میکنند، و اسکریپتهای نصب شامل تمام مراحل برای راهاندازی صحیح افزونه است. متوجه شدم که اینطور نیست و گاهی اوقات نیاز به اقدامات اضافی است.
منابع بیشتر
تعدادی دوره و پست وبلاگ وجود دارد که تنظیمات مختلف Vim را برای استفاده روزمره به عنوان توسعهدهنده پایتون پوشش میدهد، که من به شدت توصیه میکنم آنها را بررسی کنید.
هدف از دوره زیر برای شما تسلط بر Vim است روی هر سیستم عاملی، به شما کمک می کند تا سطحی از دانش و راحتی را با ویرایشگر به دست آورید که دستیابی به آن تنها با خواندن مقالات دشوار است:
بقیه منابع عالی از سراسر وب هستند که به نظر ما نیز بسیار مفید هستند:
این مقالات به گسترش دانش شما کمک می کند. لذت ببرید 🙂
سپاسگزاریها
نویسنده مایل است از Zoleka Hatitongwe برای کمک و نظرات انتقادی خود در هنگام تهیه مقاله تشکر کند.
(برچسبها به ترجمه)# python
منتشر شده در 1403-01-26 17:31:13