تابع explode() در PHP
تابع explode() یکی از توابع پایهای در PHP برای جداسازی (split) رشتهها است. با استفاده از این تابع میتوانید یک رشته را بر اساس یک جداکننده مشخص به آرایهای از زیررشتهها تبدیل کنید. این مقاله به صورت دقیق و عملیاتی به رفتار، پارامترها، نکات فنی، مثالهای واقعی و روشهای بهینهسازی در استفاده از explode() میپردازد.
تعریف و کاربرد کلی
تابع explode به شکل زیر فراخوانی میشود:
explode(string $separator, string $string, int $limit = PHP_INT_MAX): arrayاین تابع رشته $string را با جداساز $separator میشکند و آرایهای از قطعات تولید میکند. پارامتر $limit اختیاری است و رفتار خروجی را تغییر میدهد.
پارامترها (جمعبندی)
| پارامتر | توضیح |
|---|---|
| $separator | رشتهای که به عنوان جداکننده استفاده میشود. (نبايد خالی باشد) |
| $string | رشتهای که قرار است شکسته شود. |
| $limit | تعیین حداکثر تعداد عناصر خروجی یا حذف عناصر انتهایی (مثبت/منفی). |
رفتار پارامتر limit
- limit مثبت: آرایهای با حداکثر limit عنصر برمیگردد و آخرین عنصر شامل باقیماندهٔ رشته خواهد بود.
- limit منفی: تمامی قطعات به جز -limit قطعهٔ انتهایی برگردانده میشود.
- limit برابر با 1: رشتهٔ کامل بهعنوان یک عضو بازگردانده میشود (بدون شکستن).
نکته مهم: مقدار دهی limit میتواند رفتارهای گوناگونی داشته باشد؛ همیشه براساس نیاز واقعی مقدار مناسب را انتخاب کنید.
مثالهای کاربردی
// مثال ساده: جداسازی بر اساس کاما
$csv = "apple,banana,orange";
$fruits = explode(",", $csv);
// $fruits == ["apple", "banana", "orange"]
در این مثال، رشتهای که در آن عناصر با کاما جدا شدهاند به آرایهای از میوهها تبدیل میشود. explode برای پردازش سریع CSV ساده یا لیستهای ساده مفید است.
// استفاده از limit مثبت
$str = "a|b|c|d|e";
$parts = explode("|", $str, 3);
// $parts == ["a", "b", "c|d|e"]
با limit برابر 3، فقط ۳ عضو بازگردانده میشود و عضو سوم شامل باقیماندهٔ رشته خواهد بود.
// استفاده از limit منفی
$str = "1,2,3,4,5";
$parts = explode(",", $str, -2);
// $parts == ["1", "2", "3"]
با limit منفی، دو عضو انتهایی حذف شدهاند و باقی قطعات برگشت داده شدهاند.
موارد خطا و نکات ایمنی
- اگر $separator یک رشتهٔ خالی (“”) باشد، PHP هشدار صادر میکند و explode کار نخواهد کرد. بنابراین همیشه قبل از فراخوانی چک کنید که جداکننده خالی نباشد.
- explode بر بایتها عمل میکند، بنابراین در کار با رشتههای چندبایتی (UTF-8) مراقب باشید؛ برای جداسازی بر اساس کاراکترهای یونیکد از
mb_splitیاpreg_split('/.../u')استفاده کنید. - برای فرمتهایی مانند CSV که ممکن است کاما داخل quote داشته باشند، از explode استفاده نکنید و بهجای آن از
str_getcsvیا پارسکنندههای معتبر CSV استفاده کنید.
روشهای معمول برای پاکسازی نتایج
بهطور معمول پس از explode نیاز دارید که فضاهای اضافی را حذف کنید یا عناصر خالی را کنار بگذارید. ترکیب explode با توابع array_map و array_filter معمول است:
// حذف فضای اطراف و حذف عناصر خالی اما حفظ "0"
$raw = " apple , , banana,0, ,orange ";
$parts = explode(",", $raw);
$trimmed = array_map('trim', $parts);
$filtered = array_filter($trimmed, 'strlen');
// $filtered == ["apple", "banana", "0", "orange"]
در این مثال از array_map('trim', ...) برای حذف فاصلهها و از array_filter(..., 'strlen') برای حذف رشتههای طول صفر استفاده شده است. استفاده از array_filter بدون callback ممکن است مقدار “0” را حذف کند، بنابراین بهتر است از ‘strlen’ استفاده کنید تا “0” حفظ شود.
مقایسه با توابع دیگر
- explode در برابر preg_split: explode سریعتر و کمهزینهتر است اما فقط برای جداسازی ساده مناسب است. اگر نیاز به الگوهای پیچیده یا پشتیبانی از یونیکد دارید، از preg_split استفاده کنید.
- explode در برابر str_getcsv: برای CSVهای واقعی که ممکن است quote و escape داشته باشند، از str_getcsv استفاده کنید، چون explode توانایی هندل کردن quoteها را ندارد.
نمونه پیشرفته: تبدیل query string به آرایه
// parse_str انتخاب بهتری است اما با explode هم میتوان ساده انجام داد
$query = "name=ali&age=30&country=iran";
$pairs = explode("&", $query);
$result = [];
foreach ($pairs as $pair) {
list($k, $v) = explode("=", $pair, 2) + [1 => null];
$result[$k] = $v;
}
// $result == ["name" => "ali", "age" => "30", "country" => "iran"]
در این مثال ابتدا پارامترها با & جدا شدهاند، سپس هر جفت key=value با limit=2 به دو قسمت تقسیم شده تا مقدارهایی که شامل علامت = هم هستند درست پردازش شوند. توجه کنید که parse_str تابع مخصوص همین کار است و در اکثر موارد بهتر است از آن استفاده کنید زیرا کار اکستنشن متعددی انجام میدهد.
نکات عملکردی و بهترین روشها
- برای رشتههای بسیار بزرگ explode سریع و مناسب است، اما اگر نیاز به پردازش خطبهخط دارید بهتر است از توابعی مثل strtok یا پردازش جریان (stream) استفاده کنید تا حافظه کمتری مصرف شود.
- همیشه ورودیها را قبل از explode اعتبارسنجی کنید تا از هشدارهای مرتبط با جداکنندهٔ خالی یا نوع نادرست جلوگیری شود.
- در پروژههای چندزبانه و با متن یونیکد، از ابزارهای مناسب برای پردازش کاراکترهای چندبایته استفاده کنید.
خلاصه
تابع explode یکی از ابزارهای ساده و قدرتمند برای تبدیل رشته به آرایه در PHP است. با درک رفتار پارامتر limit، مراقبت از جداکنندهٔ خالی، و ترکیب با توابعی مانند array_map و array_filter میتوانید نتایج دقیق و پاکیزهای بهدست آورید. برای حالات پیچیدهتر از preg_split یا توابع مخصوص مانند str_getcsv و parse_str استفاده کنید.
آیا این مطلب برای شما مفید بود ؟



