فایلهای پیکربندی (Configuration files) راهی ساختاریافته برای مدیریت تنظیمات برنامهها فراهم میکنند که بسیار سازمانیافتهتر از صرفاً متغیرهای محیطی است. در این میان، فایلهای INI که مخفف "initialization files" هستند، با فرمت ساده و مبتنی بر بخشبندی خود، هم خواندنشان آسان است و هم تجزیه و تحلیل آنها. پایتون با ماژول داخلی و قدرتمند configparser، کار با این فایلها را بسیار ساده و مؤثر میسازد. در این بخش، به شما نشان خواهیم داد که چگونه فایلهای پیکربندی INI را با استفاده از ماژول configparser بخوانید و تجزیه کنید. برای دنبال کردن این آموزش، تنها نیاز به آشنایی اولیه با پایتون ۳.۷ به بالا و درک مفاهیم پایهای ساختار دادهها و عملیات فایل در پایتون دارید؛ هیچ بسته خارجی دیگری مورد نیاز نیست.
فایلهای INI تنظیمات را در قالب بخشها سازماندهی میکنند، به طوری که هر بخش شامل جفتهای کلید-مقدار است. این ساختار برای برنامههایی با اجزای متعدد یا محیطهای مختلف بسیار کاربردی است. به عنوان مثال، یک فایل INI میتواند شامل بخشهایی مانند database (پایگاه داده)، server (سرور) و logging (گزارشگیری) باشد که هر کدام تنظیمات مرتبط با خود را گروه بندی میکنند و در نتیجه، پیکربندی را آسانتر و قابل نگهداریتر میسازند.
ماژول configparser کلاس ConfigParser را ارائه میدهد که تمام کارهای تجزیه را انجام میدهد. روند کاری پایه شامل ایجاد یک شیء ConfigParser، خواندن فایل INI شما و سپس دسترسی به مقادیر با استفاده از یک سینتکس شبیه به دیکشنری است. در این سینتکس، براکت اول شامل نام بخش و براکت دوم شامل کلید مورد نظر است. به این ترتیب، میتوان به سادگی و به صورت منطقی به هر تنظیم دسترسی پیدا کرد و آن را بازیابی نمود.
مقادیر پیکربندی در فایلهای INI به صورت رشته ذخیره میشوند. با این حال، در برنامهنویسی اغلب نیاز است که این مقادیر را به عنوان اعداد صحیح (integer)، مقادیر بولی (boolean) یا اعداد اعشاری (float) استفاده کنیم. ماژول configparser برای این منظور، متدهای تبدیل نوع بسیار مفیدی را ارائه میدهد. متدهایی مانند getint()، getboolean() و getfloat()، مقادیر رشتهای را به نوع داده مناسب تبدیل میکنند و کار برنامهنویس را بسیار راحتتر میسازند.
علاوه بر این، در سناریوهایی که ممکن است یک کلید در فایل پیکربندی وجود نداشته باشد، configparser یک پارامتر بسیار کاربردی به نام fallback را در اختیار میگذارد. این پارامتر امکان فراهم کردن یک مقدار پیشفرض را میدهد که در صورت عدم وجود کلید مورد نظر، از آن استفاده شود. این ویژگی نه تنها از بروز خطا جلوگیری میکند، بلکه به برنامه اجازه میدهد تا با حداقل پیکربندی نیز به درستی کار کند و انعطافپذیری بیشتری را برای برنامه فراهم میآورد.
ماژول configparser تنها برای خواندن فایلهای INI نیست، بلکه قابلیت ایجاد و تغییر این فایلها را نیز دارد. این قابلیت برای ذخیره تنظیمات کاربر، ایجاد الگوهای پیکربندی یا حتی بهروزرسانی تنظیمات در زمان اجرا بسیار مفید است. با تعیین مقادیر برای بخشها و کلیدها، و سپس استفاده از متد write()، میتوانید پیکربندی را در قالب صحیح INI شامل بخشها و جفتهای کلید-مقدار ذخیره کنید.
یک رویکرد عملی و استاندارد در مدیریت پیکربندی، بستهبندی ConfigParser در یک کلاس مدیر پیکربندی (Config Manager) است. این کلاس میتواند وجود فایل را اعتبارسنجی کند و متدهای تمیزتری را برای دسترسی به تنظیمات فراهم آورد که مقادیر را با نوع داده صحیح بازمیگرداند. این الگو به نگهداری کد کمک کرده و خوانایی را افزایش میدهد.
هنگامی که متغیرهای محیطی برای مدیریت تنظیمات گروهی و مرتبط با اجزای مختلف کافی نیستند، فایلهای INI بهترین پاسخ هستند. قالب آنها خوانا برای انسان است، ConfigParser تبدیل نوع داده را به طور خودکار انجام میدهد و مهمتر از همه، این ماژول بخشی از کتابخانه استاندارد پایتون است و نیازی به نصب بستههای اضافی ندارد.
چند نکته کلیدی که باید در نظر داشته باشید:
getint()، getboolean() و getfloat() استفاده کنید؛ این متدها موارد خاص را بهتر مدیریت میکنند.fallback برای تنظیمات اختیاری، اطمینان حاصل کنید که برنامه شما با حداقل پیکربندی نیز کار میکند..ini.example با مقادیر ساختگی به عنوان الگو استفاده کنید.با رعایت این نکات، میتوانید از فایلهای INI و ماژول configparser پایتون به بهترین شکل برای مدیریت تنظیمات برنامههای خود بهره ببرید.
فایلهای پیکربندی (Configuration files) راهکاری ساختاریافته برای مدیریت تنظیمات برنامهها ارائه میدهند که سازمانیافتهتر از استفاده صرف از متغیرهای محیطی (environment variables) است. فایلهای INI، که مخفف "initialization files" هستند، به دلیل فرمت ساده و بخشبندیشدهی خود، هم به راحتی قابل خواندن هستند و هم پردازش آنها آسان است. ماژول داخلی configparser پایتون، کار با این فایلها را بسیار سرراست و قدرتمند میسازد. این بخش از مقاله به شما آموزش خواهد داد که چگونه با استفاده از ماژول configparser، فایلهای پیکربندی INI را بخوانید و مقادیر آنها را استخراج کنید. با این آموزش، با نحوه سازماندهی تنظیمات برنامههای خود به روشی کارآمد آشنا خواهید شد.
فایلهای INI پیکربندی را به صورت بخشبندی شده سازماندهی میکنند، به طوری که هر بخش شامل جفتهای کلید-مقدار (key-value pairs) است. این ساختار برای برنامههایی که دارای چندین مؤلفه یا محیط کاری متفاوت هستند، بسیار کاربردی است. به عنوان مثال، میتوانید تنظیمات مربوط به پایگاه داده، سرور و لاگگیری را در بخشهای مجزا (مانند [database]، [server] و [logging]) قرار دهید تا پیکربندی آسانتر قابل فهم و نگهداری باشد.
ماژول configparser کلاس ConfigParser را فراهم میکند که تمام کارهای مربوط به خواندن و تجزیه (parsing) این فایلها را بر عهده دارد. استفاده از این کلاس فرآیند مدیریت تنظیمات را برای توسعهدهندگان پایتون بسیار آسان کرده و نیاز به نوشتن منطق پیچیده برای خواندن دستی فایلها را از بین میبرد.
جریان کار پایه برای خواندن و دسترسی به مقادیر پیکربندی با استفاده از configparser به شرح زیر است:
ConfigParser: ابتدا یک شیء از کلاس ConfigParser ایجاد کنید.read()، فایل INI مورد نظر خود (مانند app.ini) را بخوانید.config['database']['host']).مقادیر پیکربندی که از فایلهای INI خوانده میشوند، همواره به صورت رشته (string) ذخیره میشوند. این نکته برای مدیریت صحیح انواع داده در برنامه شما حیاتی است، چرا که نیاز به تبدیل نوع مناسب را برجسته میکند.
از آنجایی که تمام مقادیر از فایلهای INI به صورت رشته خوانده میشوند، غالباً نیاز پیدا میکنید که آنها را به انواع داده مناسب برای برنامه خود (مانند اعداد صحیح، مقادیر بولی یا اعداد اعشاری) تبدیل کنید. ماژول configparser برای این منظور متدهای بسیار کارآمدی را ارائه میدهد که فرآیند تبدیل نوع را ایمنتر و آسانتر میکنند:
getint('section', 'key'): برای تبدیل مقدار رشتهای به عدد صحیح.getboolean('section', 'key'): برای تبدیل مقادیر رشتهای به مقادیر بولی (مانند True یا False). این متد به طور هوشمند رشتههایی مانند "yes", "on", "true", "1" را به True و "no", "off", "false", "0" را به False تبدیل میکند.getfloat('section', 'key'): برای تبدیل مقدار رشتهای به عدد اعشاری.استفاده از این متدها نه تنها از نیاز به تبدیل دستی جلوگیری میکند، بلکه آنها موارد خاص و خطاهای احتمالی در حین تبدیل را نیز بهتر مدیریت میکنند. یکی از ویژگیهای قدرتمند این متدها، پارامتر fallback است که به شما امکان میدهد یک مقدار پیشفرض را مشخص کنید. اگر کلید مورد نظر در فایل پیکربندی وجود نداشته باشد، از این مقدار پیشفرض استفاده میشود. این قابلیت به طور چشمگیری پایداری برنامه شما را افزایش میدهد و از بروز خطاهای ناخواسته جلوگیری میکند.
برای اطمینان از مدیریت بهینه فایلهای پیکربندی INI در پروژههایتان، رعایت نکات زیر ضروری است:
getint()، getboolean() و getfloat() استفاده کنید. آنها موارد خاص را بهتر مدیریت میکنند.fallback برای تنظیمات اختیاری، مقادیر پیشفرض منطقی تعریف کنید..ini.example با مقادیر نمونه به عنوان الگو استفاده کنید.در نهایت، وقتی متغیرهای محیطی برای مدیریت تنظیمات گروهی کافی نیستند، فایلهای INI راه حل مناسبی هستند. فرمت آنها خوانا برای انسان است، configparser تبدیل نوع را به طور خودکار انجام میدهد، و این ماژول بخشی از کتابخانه استاندارد پایتون است.
فایلهای پیکربندی INI، مقادیر تنظیمات را به صورت رشتههای متنی ذخیره میکنند. با این حال، در توسعه برنامههای کاربردی، اغلب نیاز داریم که این مقادیر را به انواع دادههای مشخصی مانند اعداد صحیح، مقادیر بولی یا اعداد اعشاری تبدیل کنیم. ماژول داخلی configparser پایتون، ابزارهای قدرتمندی برای تبدیل این رشتهها به انواع دادههای مناسب و همچنین تعریف مقادیر پیشفرض برای کلیدهای پیکربندی که ممکن است وجود نداشته باشند، ارائه میدهد. این قابلیتها به پایداری، خوانایی و انعطافپذیری کد شما کمک شایانی میکنند. در ادامه به بررسی چگونگی استفاده از این متدها خواهیم پرداخت تا بتوانید با اطمینان بیشتری فایلهای پیکربندی INI را در پروژههای پایتون خود مدیریت کنید.
همانطور که میدانید، ساختار فایلهای INI ساده است و تمامی مقادیر، از شماره پورت گرفته تا وضعیت فعال/غیرفعال بودن یک ویژگی، به صورت متن (رشته) ذخیره میشوند. به عنوان مثال، مقدار port=8080 به صورت رشته "8080" و debug=True به صورت رشته "True" ذخیره میشود. این رویکرد، خوانایی فایل پیکربندی را برای انسان افزایش میدهد. اما هنگامی که برنامه پایتون شما این مقادیر را میخواند، برای انجام عملیات منطقی یا ریاضی، به نوع داده صحیح آنها نیاز دارد. تلاش برای انجام عملیات روی یک رشته به جای عدد صحیح یا بولی، میتواند منجر به خطاهای زمان اجرا (Runtime Errors) شود.
تبدیل دستی این رشتهها با استفاده از توابع int()، float() یا بررسیهای شرطی برای مقادیر بولی، میتواند مستعد خطا باشد و کد را پیچیدهتر کند. برای مثال، یک رشته غیرعددی در int() خطا ایجاد میکند، و مدیریت تمامی حالات ممکن برای یک مقدار بولی (مانند "True", "true", "1", "YES" در مقابل "False", "false", "0", "NO") نیازمند منطق پیچیدهای است. configparser با تشخیص این نیازها، این فرآیند را با متدهای داخلی خود بهینه و ایمن میکند.
ماژول configparser برای سادهسازی فرآیند تبدیل نوع دادهها، متدهای اختصاصی را در اختیار توسعهدهندگان قرار میدهد. این متدها نه تنها تبدیل را به درستی انجام میدهند، بلکه در برابر فرمتهای مختلف ورودی نیز انعطافپذیرتر بوده و بسیاری از حالات لبهای را مدیریت میکنند. استفاده از این متدها به جای تبدیل دستی اکیداً توصیه میشود:
getint(section, option, fallback=...): این متد، مقدار مربوط به option را از section دریافت کرده و آن را به یک عدد صحیح تبدیل میکند. برای پارامترهایی مانند شماره پورت، تعداد اتصالات یا زمانبندیها بسیار مناسب است. در صورت عدم امکان تبدیل به عدد صحیح و عدم وجود fallback، خطای ValueError رخ میدهد.getboolean(section, option, fallback=...): برای مقادیر بولی، این متد رشتههایی مانند "yes", "true", "on", "1" (بدون حساسیت به حروف) را به True و رشتههایی مانند "no", "false", "off", "0" را به False تبدیل میکند. این انعطافپذیری، فایلهای پیکربندی را هم برای انسان و هم برای برنامه خواناتر میسازد. در صورت مواجه شدن با مقادیر نامعتبر و عدم وجود fallback، خطای ValueError صادر میشود.getfloat(section, option, fallback=...): این متد مقادیر رشتهای را به اعداد اعشاری (float) تبدیل میکند. برای تنظیماتی که نیاز به دقت اعشاری دارند، مانند ضرایب یا مقیاسها، کاربردی است. مانند getint()، در صورت نامعتبر بودن فرمت و عدم وجود fallback، خطای ValueError رخ خواهد داد.
این متدهای تخصصی، نه تنها کد را تمیزتر نگه میدارند، بلکه با هندل کردن هوشمندانه فرمتهای مختلف و حالات خاص، مقاومت برنامه شما را در برابر پیکربندیهای غیرمنتظره به شکل چشمگیری افزایش میدهند. استفاده از آنها یک رویه استاندارد و توصیه شده است.
در بسیاری از سناریوها، ممکن است یک کلید پیکربندی در فایل INI وجود نداشته باشد، اما برنامه همچنان باید بتواند با یک مقدار پیشفرض منطقی به کار خود ادامه دهد. اینجاست که پارامتر fallback در متدهای get() و متدهای تبدیل نوع (getint()، getboolean()، getfloat()) به کمک میآید. پارامتر fallback به شما امکان میدهد تا یک مقدار را مشخص کنید که در صورت پیدا نشدن کلید مورد نظر در فایل پیکربندی، به جای پرتاب خطا، به عنوان خروجی بازگردانده شود.
این ویژگی برای تنظیمات اختیاری که برنامه میتواند بدون آنها نیز کار کند یا مقادیر پیشفرض استانداردی برای آنها وجود دارد، فوقالعاده مفید است. به عنوان مثال، اگر برنامه شما به یک timeout (مهلت زمانی) برای اتصال نیاز دارد، اما کاربر این کلید را در فایل app.ini وارد نکرده است، میتوانید با config.getint('server', 'timeout', fallback=30) یک مقدار پیشفرض 30 ثانیه را برای آن تعیین کنید. این کار از کرش کردن برنامه جلوگیری کرده و تضمین میکند که برنامه حتی با حداقل تنظیمات نیز قابلیت اجرا داشته باشد.
استفاده از fallback نه تنها خطاهای مربوط به عدم وجود کلید را از بین میبرد، بلکه به برنامههای شما انعطافپذیری بیشتری میبخشد و تجربه کاربری را بهبود میبخشد، زیرا کاربر مجبور نیست تمام تنظیمات را از ابتدا پیکربندی کند. همیشه مقادیر پیشفرض معقول و ایمن را انتخاب کنید تا رفتار برنامه قابل پیشبینی باقی بماند و از بروز رفتارهای ناخواسته جلوگیری شود.
در مجموع، قابلیتهای تبدیل نوع و مدیریت مقادیر پیشفرض در configparser، ابزارهای حیاتی برای ساخت سیستمهای پیکربندی قدرتمند و مقاوم هستند. با استفاده از متدهای getint()، getboolean() و getfloat() به جای تبدیل دستی و بهرهگیری از پارامتر fallback برای تنظیمات اختیاری، میتوانید کدی بنویسید که نه تنها خواناتر است، بلکه در برابر خطاهای احتمالی پیکربندی نیز مقاومتر عمل میکند. همیشه به یاد داشته باشید که برای امنیت، هرگز اطلاعات حساس مانند رمز عبور را مستقیماً در فایلهای INI ذخیره و به کنترل نسخه (مانند گیت) اضافه نکنید؛ از فایلهای .ini.example با مقادیر نمونه استفاده کنید.
با وجود اینکه ماژول configparser پایتون ابزاری قدرتمند برای خواندن و نوشتن فایلهای INI فراهم میکند، اما در برنامههای بزرگتر و پیچیدهتر، مدیریت مستقیم شیء ConfigParser در تمام بخشهای کد میتواند منجر به تکرار کد و دشواری در نگهداری شود. یک رویکرد عملی و حرفهای، بستهبندی (wrapping) ConfigParser در یک کلاس مدیریتی است. این کلاس که میتوانیم آن را ConfigManager بنامیم، مسئولیت اعتبارسنجی پیکربندی و ارائه یک رابط کاربری ساده و تمیز برای دسترسی به تنظیمات را بر عهده میگیرد.
هدف اصلی از ایجاد چنین کلاسی، تجرید پیچیدگیهای مرتبط با خواندن فایلهای INI، انجام تبدیل نوع دادهها و اعمال مقادیر پیشفرض است. با این کار، سایر بخشهای برنامه نیازی به دانستن جزئیات پیادهسازی ندارند و فقط با فراخوانی متدهای مشخصی از کلاس ConfigManager، به تنظیمات مورد نیاز خود دسترسی پیدا میکنند. این رویکرد نه تنها کد را خواناتر میکند، بلکه قابلیت نگهداری و گسترشپذیری آن را نیز به طرز چشمگیری بهبود میبخشد.
در یک برنامه کاربردی، تنظیمات اغلب شامل جزئیات حساس و حیاتی هستند؛ از اطلاعات اتصال به پایگاه داده گرفته تا تنظیمات سرور و سطح لاگگیری. مدیریت این تنظیمات به صورت پراکنده در سراسر کد، خطاهای رایجی مانند دسترسی به کلیدهای ناموجود یا عدم تبدیل صحیح انواع داده را در پی دارد. یک کلاس ConfigManager این امکان را میدهد که تمام منطق مربوط به بارگذاری، اعتبارسنجی و دسترسی به تنظیمات در یک مکان متمرکز شود.
یکی از مهمترین مزایای این کلاس، قابلیت اعتبارسنجی زودهنگام است. به جای اینکه برنامه در حین اجرا به دلیل عدم وجود یک بخش یا کلید ضروری دچار خطا شود، کلاس مدیر تنظیمات میتواند بلافاصله پس از بارگذاری فایل، وجود بخشها و کلیدهای حیاتی را بررسی کرده و در صورت نیاز، خطاهای مناسب را صادر کند. همچنین، این کلاس میتواند اطمینان حاصل کند که مقادیر بازیابی شده، همیشه با نوع دادهای که برنامه انتظار دارد (مانند عدد صحیح، بولی یا اعشاری) مطابقت دارند، حتی اگر در فایل INI به صورت رشته ذخیره شده باشند.
برای طراحی یک کلاس ConfigManager، میتوانیم به شکلی عمل کنیم که از قدرت ConfigParser استفاده کند اما یک لایه انتزاعی روی آن ایجاد نماید. این کلاس باید در زمان نمونهسازی، مسیر فایل INI را دریافت کرده و آن را بارگذاری کند. سپس، متدهایی را ارائه دهد که به توسعهدهندگان اجازه میدهد تا به راحتی به تنظیمات مربوط به بخشهای مختلف (مانند database، server یا logging) دسترسی پیدا کنند. هر یک از این متدها میتواند یک دیکشنری حاوی کلید-مقدار مربوط به آن بخش را برگرداند که مقادیر آن به درستی تبدیل نوع شدهاند.
متدهای دسترسی به تنظیمات در کلاس ConfigManager باید از متدهای تبدیل نوع ConfigParser مانند getint()، getboolean() و getfloat() استفاده کنند. این کار تضمین میکند که تبدیل نوع به درستی انجام میشود و همچنین به مدیریت موارد خاص (edge cases) کمک میکند. علاوه بر این، استفاده از پارامتر fallback در این متدها بسیار مهم است. با تعیین مقادیر پیشفرض معقول، برنامه حتی با یک فایل پیکربندی حداقل نیز میتواند به درستی کار کند و از خطاهای ناشی از عدم وجود یک کلید اختیاری جلوگیری شود.
به عنوان مثال، فرض کنید فایل app.ini شامل تنظیمات پایگاه داده، سرور و لاگگیری است. کلاس ConfigManager میتواند متدهایی مانند get_database_settings()، get_server_settings() و get_logging_settings() داشته باشد. این متدها با فراخوانی config.items('section_name') یا دسترسی مستقیم به کلیدها با تبدیل نوع مناسب، تنظیمات مربوط به هر بخش را به صورت یک دیکشنری مرتب و با مقادیر تبدیل شده برمیگردانند. این روش استفاده از تنظیمات را بسیار شفافتر و ایمنتر میکند.
استفاده از یک کلاس اختصاصی برای مدیریت تنظیمات، مزایای عملی متعددی را به همراه دارد که فراتر از خوانایی کد است:
ConfigParser دست و پنجه نرم کنند، فقط متدهای تعریفشدهای را فراخوانی میکنند که دادههای مورد نیاز را در قالب مطلوب برمیگرداند.ConfigManager تأثیر میگذارد و نیازی به تغییر در سایر قسمتهای برنامه نیست.همچنین، در هنگام طراحی و پیادهسازی چنین کلاسی، رعایت برخی بهترین شیوهها ضروری است:
ConfigParser:** همیشه از getint()، getboolean() و getfloat() استفاده کنید تا تبدیل نوع به صورت ایمن و خودکار انجام شود.fallback برای کلیدهای اختیاری استفاده کنید تا برنامه شما با حداقل تنظیمات نیز کار کند..ini.example با مقادیر ساختگی به عنوان الگو استفاده کنید.در نهایت، با ایجاد یک کلاس ConfigManager، شما یک راه حل قوی و مقیاسپذیر برای مدیریت تنظیمات برنامه خود ایجاد میکنید که به خوانایی، نگهداری و پایداری کد شما کمک شایانی میکند.
فایلهای پیکربندی INI تنها برای خواندن تنظیمات کاربرد ندارند؛ ماژول configparser در پایتون قابلیت قدرتمندی برای ایجاد و ویرایش این فایلها نیز ارائه میدهد. این ویژگی به توسعهدهندگان امکان میدهد تا به صورت برنامهنویسی، فایلهای تنظیمات جدید بسازند یا تغییرات لازم را در فایلهای موجود اعمال کنند. این قابلیت برای ذخیره ترجیحات کاربر، ایجاد قالبهای پیکربندی پیشفرض یا مدیریت تنظیمات پویا بسیار کاربردی است.
برای ایجاد یک فایل INI جدید، ابتدا یک نمونه از ConfigParser بسازید. سپس با add_section() بخشها را اضافه کرده و با ساختار config['section']['key'] = 'value' جفتکلید-مقدارها را مشخص کنید. در نهایت، متد write() پیکربندی را در یک شیء فایل قابل نوشتن ذخیره میکند. این فرآیند تضمین میکند که فایل خروجی با فرمت استاندارد INI کاملاً خوانا و قابل تجزیه باشد.
ویرایش فایلهای موجود نیز ساده است. ابتدا فایل را با read() در ConfigParser بارگذاری کنید. سپس میتوانید مقادیر کلیدهای موجود را تغییر دهید یا کلیدها و بخشهای جدیدی اضافه کنید. برای حذف کلید یا بخش، از remove_option() و remove_section() استفاده کنید. پس از اعمال تغییرات، مجدداً از write() برای بازنویسی فایل با تنظیمات جدید استفاده کنید.
فایلهای پیکربندی روشی ساختاریافته برای مدیریت تنظیمات برنامه هستند که منظمتر از متغیرهای محیطی عمل میکنند. فایلهای INI، با فرمت ساده و بخشبندیشدهشان، هم به راحتی قابل خواندن و هم تجزیه هستند. ماژول داخلی configparser پایتون کار با این فایلها را ساده و قدرتمند میسازد. این راهنما به شما نحوه خواندن و تجزیه فایلهای INI را با این ماژول میآموزد. برای دنبال کردن، به پایتون ۳.۷ یا بالاتر، درک اولیه از پایتون، آشنایی با عملیات فایلها و یک ویرایشگر کد نیاز دارید. هیچ بسته خارجی لازم نیست.
فایلهای INI تنظیمات را به بخشهایی سازماندهی میکنند که هر بخش شامل جفتکلید-مقدارها است. این ساختار برای برنامههایی با چندین مؤلفه یا محیط مفید است. برای مثال، یک فایل INI میتواند شامل بخشهای [database]، [server] و [logging] باشد که هر کدام تنظیمات مرتبط خود را گروهبندی میکنند. این سازماندهی، درک و نگهداری پیکربندی را آسانتر میکند.
ماژول configparser کلاس ConfigParser را ارائه میدهد که تمام کارهای تجزیه را انجام میدهد. برای خواندن و دسترسی به مقادیر: ابتدا یک شیء ConfigParser ایجاد کنید، سپس با read() فایل INI خود را بخوانید. پس از آن، با نحو شبیه دیکشنری به مقادیر دسترسی پیدا کنید (مثلاً: config['database']['host']). این روش دسترسی مستقیم و شهودی به تنظیمات را فراهم میکند.
مقادیر در فایلهای INI به صورت رشته ذخیره میشوند، اما اغلب به نوعهای int، boolean یا float نیاز دارند. ConfigParser متدهای مناسبی مانند getint(), getboolean(), و getfloat() برای تبدیل نوع دادهها ارائه میدهد. این متدها رشتهها را به نوع مناسب تبدیل کرده و حالات خاص را بهتر مدیریت میکنند. پارامتر fallback نیز یک مقدار پیشفرض زمانی که کلید وجود ندارد، فراهم میکند و از بروز خطا جلوگیری میکند.
یک رویکرد عملی، بستهبندی ConfigParser در یک کلاس سفارشی است که پیکربندی را اعتبارسنجی کرده و دسترسی آسان به تنظیمات را فراهم میآورد. این کلاس مدیر، وجود فایل را تأیید و متدهای تمیزی برای دسترسی به پیکربندی ارائه میدهد. با برگرداندن دیکشنریهایی با مقادیر دارای نوع مناسب، این کلاس به شما کمک میکند تا کدی خواناتر و قابل نگهداریتر داشته باشید.
میتوانید بخشهای مختلف برنامه را در فایل INI سازماندهی کرده و به آنها دسترسی یابید. متد dict() تمام جفتکلید-مقادیر یک بخش را به صورت یکجا برمیگرداند. همچنین، has_section() به شما امکان میدهد بخشهای پیکربندی اختیاری را به صورت شرطی مدیریت کنید و اطمینان حاصل کنید که برنامه شما بدون نیاز به همه بخشها نیز به درستی کار میکند.
فایلهای INI راهحلی عالی برای مدیریت تنظیمات گروهبندی شده هستند؛ فرمت آنها انسانخوان است و Configparser پایتون به صورت خودکار تبدیل نوع دادهها را مدیریت میکند. توصیه میشود Configparser را در یک کلاس برای اعتبارسنجی و دسترسی تمیزتر بستهبندی کنید. نکات مهم: ۱. بر اساس مؤلفه سازماندهی کنید: از بخشها برای گروهبندی تنظیمات استفاده کنید. ۲. از متدهای تبدیل نوع داده استفاده کنید: همیشه getint(), getboolean(), getfloat() را به جای تبدیل دستی به کار ببرید. ۳. پیشفرضهای منطقی ارائه دهید: از fallback برای تنظیمات اختیاری استفاده کنید. ۴. زودهنگام اعتبارسنجی کنید: در راهاندازی، وجود بخشها و کلیدهای ضروری را بررسی کنید. ۵. اسرار را جدا نگه دارید: فایلهای INI حاوی رمز عبور را در کنترل نسخه قرار ندهید؛ از ini.example به عنوان الگو استفاده کنید.