مقالات

راهنمای جامع کاراکتر نفی [^] در Regex: چگونه کاراکترها را مستثنی کنیم؟

راهنمای جامع کاراکتر نفی [^] در Regex: چگونه کاراکترها را مستثنی کنیم؟

عبارات منظم (Regex) مجموعه‌ای قدرتمند از نمادها برای تعریف الگوهای جستجو در متن هستند. درک دقیق متاکاراکترها و دستورات اصلی رجکس برای هرگونه پردازش متن پیشرفته، ضروری است. یکی از گیج‌کننده‌ترین نمادها در این میان، ^ (Caret) است؛ زیرا بسته به موقعیت قرارگیری، دو نقش کاملاً متفاوت و حیاتی را ایفا می‌کند.

این نماد هم می‌تواند به معنای «شروع خط» (Anchor) باشد و هم به عنوان اپراتور «نفی» (Negation) عمل کند. اشتباه گرفتن این دو کاربرد، یکی از رایج‌ترین دلایل شکست الگوهای جستجو و سردرگمی توسعه‌دهندگان است. در این مطلب، به شکل دقیق و با مثال‌های عملی، روی کاربرد دوم، یعنی کلاس کاراکتر نفی شده [^…]، تمرکز می‌کنیم و تفاوت‌های آن را به طور کامل روشن خواهیم کرد.

جدول مقایسه سریع: ^ (لنگر) در مقابل [^…] (نفی)

ویژگی ^ (خارج از براکت) [^…] (داخل براکت)
نقش اصلی لنگر (Anchor) کلاس کاراکتر نفی شده (Negation)
معنای تحت‌اللفظی «شروع خط» یا «شروع رشته» «به جز» یا «هر کاراکتری غیر از…»
چه چیزی را مطابقت می‌دهد؟ یک موقعیت (Position) یک کاراکتر تکی (Character)
آیا کاراکتری مصرف می‌کند؟ خیر (Zero-width assertion) بله (یک کاراکتر را مصرف می‌کند)
مثال الگو ^A [^A]
توضیح مثال رشته‌ای که باید با ‘A’ شروع شود. هر کاراکتر تکی که ‘A’ نباشد.

کاراکتر نفی [^] در Regex چیست؟ (تعریف و مفهوم)

کاراکتر ^ (Caret) هنگامی که به عنوان اولین کاراکتر در داخل یک «کلاس کاراکتر» (Character Class) یا همان [] استفاده شود، به یک متاکاراکتر خاص تبدیل می‌شود که معنای «نفی» یا «به جز» (Not) را می‌رساند.

به ساختاری مانند [^…]، «کلاس کاراکتر نفی شده» (Negated Character Class) گفته می‌شود. وظیفه اصلی این ساختار، مطابقت با هر کاراکتر تکی است که در لیست مشخص شده در ادامه آن، وجود نداشته باشد.

 معنای دقیق «کلاس کاراکتر نفی شده» (Negated Character Class)

برای درک بهتر این مفهوم، ابتدا یک کلاس کاراکتر استاندارد را در نظر بگیرید:

  • کلاس استاندارد: الگوی [abc] به موتور Regex می‌گوید که فقط با یکی از حروف ‘a’ یا ‘b’ یا ‘c’ مطابقت پیدا کند.

حالا، با افزودن ^ در ابتدای آن، معنا کاملاً برعکس می‌شود:

  • کلاس نفی شده: الگوی [^abc] با هر کاراکتر تکی مطابقت پیدا می‌کند، به جز ‘a’، ‘b’ یا ‘c’.

این «هر کاراکتر» شامل حروف دیگر (مانند ‘d’, ‘z’, ‘M’)، اعداد (مانند ‘1’, ‘9’)، فاصله‌ها، کاراکترهای خاص (مانند ‘!’, ‘@’) و معمولاً حتی کاراکترهای خط جدید (Newline) می‌شود.

 این اپراتور دقیقاً چه چیزی را مطابقت می‌دهد؟

نکته بسیار مهمی که باید به آن توجه کرد، این است که [^…] همچنان یک کاراکتر را مطابقت می‌دهد.

این الگو به معنای «هیچ چیز» یا «عدم وجود کاراکتر» نیست. بلکه به معنای «یک کاراکتر پیدا کن، به شرطی که آن کاراکتر در این لیست ممنوعه نباشد» است.

مثال کاربردی:

فرض کنید می‌خواهید هر کاراکتری را پیدا کنید که یک حرف صدادار انگلیسی (کوچک یا بزرگ) نیست. می‌توانید از این الگو استفاده کنید:

[^aeiouAEIOU]

این الگو با ‘b’, ‘c’, ‘1’, ‘!’, ‘ ‘ (فاصله) و… مطابقت دارد، اما به محض رسیدن به ‘a’ یا ‘E’، آن را نادیده می‌گیرد.

 جایگاه [^] در میان متاکاراکترهای Regex

بزرگترین منبع سردرگمی در مورد ^ این است که این کاراکتر دو نقش کاملاً متفاوت در Regex دارد که صرفاً به موقعیت آن بستگی دارد:

۱. لنگر شروع رشته (Start of String Anchor):

وقتی ^ در خارج از [] و معمولاً در ابتدای کل الگو قرار می‌گیرد، به معنای «شروع رشته» است.

  • مثال: ^Report به این معناست که رشته باید با کلمه “Report” شروع شود.

۲. نفی‌کننده کلاس کاراکتر (Negated Character Class):

وقتی ^ در داخل [] و به عنوان اولین کاراکتر قرار می‌گیرد، معنای «نفی» دارد.

  • مثال: [^R] یعنی «هر کاراکتری به جز R».

نکته کلیدی: اگر ^ در داخل [] باشد اما اولین کاراکتر نباشد، معنای خاص خود را از دست می‌دهد و دقیقاً به عنوان خودِ کاراکترِ «Caret» (هشت) در نظر گرفته می‌شود.

  • مثال: [a^b] به معنای «یکی از کاراکترهای ‘a’ یا ‘^’ یا ‘b’» است.

تفاوت حیاتی: [^] (داخل براکت) در مقابل ^ (خارج از براکت)

تفاوت اصلی در این است که ^ در خارج از براکت، یک «موقعیت» (Position) را بررسی می‌کند، در حالی که [^…] در داخل براکت، یک «کاراکتر» (Character) را مطابقت می‌دهد.

به عبارت ساده‌تر:

  • ^ (خارج از براکت): به معنای «شروع رشته» است. این یک «لنگر» (Anchor) محسوب می‌شود و بخشی از متن مصرفی (Consumed) نیست.
  • [^…] (داخل براکت): به معنای «به جز اینها» است. این یک «کلاس کاراکتر نفی شده» (Negated Character Class) است و یک کاراکتر تکی را از متن مطابقت داده و مصرف می‌کند.

 درک ^ به عنوان لنگر (Anchor): تطبیق «شروع خط»

وقتی کاراکتر ^ در خارج از [] قرار می‌گیرد (و معمولاً در ابتدای کل الگوی Regex)، به عنوان یک «لنگر» عمل می‌کند.

لنگرها کاراکترها را مطابقت نمی‌دهند، بلکه موقعیت‌های خاصی را در رشته بررسی می‌کنند. لنگر ^ به طور خاص، موقعیت قبل از اولین کاراکتر رشته را بررسی می‌کند.

  • الگو: ^Hello
  • معنا: این الگو به موتور Regex دستور می‌دهد که بررسی کند آیا رشته مورد نظر دقیقاً با کلمه “Hello” شروع می‌شود یا خیر.
  • مثال:
    • در رشته “Hello World”: مطابقت دارد.
    • در رشته “Say Hello”: مطابقت ندارد (چون “Hello” در شروع رشته نیست).

درک [^…] به عنوان اپراتور نفی: تطبیق «هر کاراکتر به جز…»

وقتی کاراکتر ^ داخل [] و به عنوان اولین کاراکتر آن قرار می‌گیرد، نقش آن کاملاً عوض شده و به «اپراتور نفی» تبدیل می‌شود.

این ساختار، که «کلاس کاراکتر نفی شده» نام دارد، با هر کاراکتر تکی مطابقت پیدا می‌کند، به شرطی که آن کاراکتر در لیستی که جلوی ^ آمده است، نباشد.

  • الگو: [^H]
  • معنا: این الگو با هر کاراکتر تکی مطابقت دارد، به جز حرف ‘H’ بزرگ.
  • مثال:
    • در رشته “Hello”:
      • ‘H’ را مطابقت نمی‌دهد.
      • ‘e’ را مطابقت می‌دهد.
      • ‘l’ را مطابقت می‌دهد.
      • ‘l’ دوم را مطابقت می‌دهد.
      • ‘o’ را مطابقت می‌دهد.

 جدول مقایسه‌ای: تفاوت رفتار [^a] و ^a در عمل

برای روشن شدن کامل موضوع، مقایسه مستقیم این دو الگو در یک جدول می‌تواند بسیار مفید باشد:

ویژگی ^a (لنگر) [^a] (کلاس نفی شده)
نقش اصلی لنگر شروع رشته (Start Anchor) کلاس کاراکتر نفی شده (Negation)
محل استفاده خارج از براکت [] داخل براکت [] (به عنوان کاراکتر اول)
چه چیزی را مطابقت می‌دهد؟ یک موقعیت (Position) یک کاراکتر تکی (Single Character)
معنای الگو “رشته‌ای که با ‘a’ شروع شود.” “هر کاراکتر تکی، به جز ‘a’.”
مثال در رشته “apple مطابقت دارد. (چون رشته با ‘a’ شروع شده) مطابقت ندارد. (چون اولین کاراکتر ‘a’ است و در لیست ممنوعه قرار دارد)
مثال در رشته “banana مطابقت ندارد. (چون رشته با ‘b’ شروع شده) مطابقت دارد. (اولین کاراکتر ‘b’ است که ‘a’ نیست)

به طور خلاصه، ^ به تنهایی، شرطی برای شروع رشته است، در حالی که [^…] ابزاری برای انتخاب کاراکترهایی است که در یک لیست مشخص وجود ندارند.

آموزش گام به گام و مثال‌های عملی استفاده از [^]

قدرت واقعی «کلاس کاراکتر نفی شده» (Negated Character Class) در توانایی آن برای «فیلتر کردن» است. به جای اینکه مشخص کنید چه چیزی می‌خواهید، به سادگی مشخص می‌کنید چه چیزی را نمی‌خواهید. این رویکرد می‌تواند الگوهای پیچیده را بسیار ساده‌تر کند.

مثال ۱ (ساده): حذف حروف صدادار از یک رشته (مانند [^aeiou])

در اینجا یک سوتفاهم رایج وجود دارد که باید روشن شود. الگوی [^aeiou] (با فرض نادیده گرفتن حروف بزرگ) به معنای «هر کاراکتری که حرف صدادار نیست» می‌باشد.

بنابراین، این الگو حروف صدادار را حذف نمی‌کند، بلکه برعکس، تمام کاراکترهای دیگر (حروف بی‌صدا، اعداد، فاصله‌ها، علائم نگارشی و…) را انتخاب می‌کند.

  • الگو: [^aeiou]
  • رشته ورودی: “This is a test.”
  • نتایج مطابقت: ‘T’, ‘h’, ‘s’, ‘ ‘, ‘s’, ‘ ‘, ‘ ‘, ‘t’, ‘s’, ‘t’, ‘.’

اگر هدف شما دقیقاً حذف حروف صدادار بود، باید از الگوی معکوس آن یعنی [aeiou] (بدون نفی) استفاده می‌کردید و نتایج یافت شده را با یک رشته خالی جایگزین (Replace) می‌کردید.

 مثال ۲ (ترکیبی): پیدا کردن خطوطی که با کاراکتر خاصی شروع نمی‌شوند (مانند ^[^#])

این یک مثال عالی از ترکیب دو کاربرد کاملاً متفاوت کاراکتر ^ در یک الگو است. این الگو اغلب برای پردازش فایل‌های پیکربندی (Config files) استفاده می‌شود که در آن خطوط کامنت با # مشخص می‌شوند.

  • الگو: ^[^#]
  • تحلیل الگو:
    1. ^ (اولین کاراکتر): این «لنگر شروع خط» (Start Anchor) است. به موتور Regex دستور می‌دهد که فقط به ابتدای خط نگاه کند.
    2. [^#] (بخش دوم): این «کلاس نفی شده» است. می‌گوید کاراکتری که در این موقعیت (یعنی اولین کاراکتر خط) قرار دارد، باید هر چیزی به جز # باشد.
  • کاربرد: این الگو با هر خطی که کاراکتر اول آن # نباشد، مطابقت پیدا می‌کند و به شما اجازه می‌دهد تمام خطوطی که کامنت نیستند را به سادگی فیلتر کنید.
  • مثال:
    • #Setting=Value (مطابقت ندارد)
    • Run=True (مطابقت دارد)
    • Another=False (مطابقت دارد، زیرا اولین کاراکتر «فاصله» است که «#» نیست)

مثال ۳ (اعتبارسنجی): اطمینان از اینکه رشته شامل کاراکترهای غیرمجاز است

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

  • سناریو: فرض کنید یک نام کاربری (Username) فقط می‌تواند شامل حروف انگلیسی، اعداد و آندرلاین (_) باشد.
  • الگوی کاراکترهای مجاز: [a-zA-Z0-9_]
  • الگوی پیدا کردن کاراکترهای غیرمجاز: [^a-zA-Z0-9_]
  • کاربرد:
    • ورودی: “Valid_User123”
    • نتیجه: الگوی [^a-zA-Z0-9_] هیچ کاراکتری را پیدا نمی‌کند. (ورودی معتبر است)
    • ورودی: “Invalid@User!”
    • نتیجه: الگو کاراکترهای @ و ! را پیدا می‌کند. (ورودی نامعتبر است)

 استفاده از بازه‌ها (Ranges) در کنار نفی (مثال: [^a-zA-Z0-9])

شما مجبور نیستید تک تک کاراکترها را در کلاس نفی شده لیست کنید. «بازه‌ها» (Ranges) مانند a-z یا 0-9 در داخل ساختار نفی کاملاً به درستی کار می‌کنند.

مثالی که در عنوان آمده است، یک الگوی بسیار رایج برای پیدا کردن «کاراکترهای ویژه» (Special Characters) است.

  • الگو: [^a-zA-Z0-9]
  • معنا: “هر کاراکتر تکی را پیدا کن که:
    • نه یک حرف کوچک انگلیسی (خارج از بازه a-z)
    • و نه یک حرف بزرگ انگلیسی (خارج از بازه A-Z)
    • و نه یک عدد (خارج از بازه 0-9) باشد.”
  • کاربرد: این الگو به طور مؤثر تمام علائم نگارشی، فاصله‌ها، نمادها و… را مطابقت می‌دهد.
  • مثال در رشته “Test@100%!”:
    • نتایج مطابقت: ‘@’, ‘%’ , ‘!’

اشتباهات رایج و دام‌های استفاده از [^] (بر اساس تجربه)

درک تئوری [^…] یک چیز است و استفاده درست از آن در عمل، چیزی دیگر. بسیاری از افراد تازه‌کار و حتی باتجربه، به دلیل درک نادرست از رفتار این اپراتور، دچار مشکل می‌شوند. اینها رایج‌ترین اشتباهاتی هستند که من مشاهده کرده‌ام.

 اشتباه رایج ۱: فراموش کردن اینکه [^] همچنان باید یک کاراکتر را تطبیق دهد

این رایج‌ترین و بزرگ‌ترین سوتفاهم است.

بسیاری به اشتباه تصور می‌کنند که [^a] به معنای «اگر ‘a’ وجود نداشت» یا «هیچ چیز» است. این کاملاً نادرست است. ساختار [^…] یک «کلاس کاراکتر» است و قانون تمام کلاس‌های کاراکتر این است که باید دقیقاً یک کاراکتر را از رشته مطابقت دهند (مصرف کنند).

  • الگو: [^a]
  • معنای اشتباه: «نبود کاراکتر ‘a’»
  • معنای درست: «یک کاراکتر تکی پیدا کن که ‘a’ نباشد.»

مثال:

  • رشته: “abc”
    • الگوی [^a] کاراکتر اول (‘a’) را رد می‌کند، اما کاراکتر دوم (‘b’) را با موفقیت مطابقت می‌دهد.
  • رشته: “a”
    • الگوی [^a] شکست می‌خورد، چون تنها کاراکتر موجود در لیست ممنوعه است.
  • رشته: “” (رشته خالی)
    • الگوی [^a] شکست می‌خورد، چون هیچ کاراکتری برای مطابقت دادن وجود ندارد.

 اشتباه رایج ۲: سردرگمی در مورد کاراکترهای خاص داخل براکت نفی (مانند . یا *)

یکی دیگر از نقاط قوت و در عین حال گیج‌کننده در Regex این است که متاکاراکترها (نمادهای خاص) وقتی داخل یک کلاس کاراکتر [] قرار می‌گیرند، معنای خاص خود را از دست می‌دهند. این قانون برای کلاس نفی شده [^…] نیز صادق است.

  • کاراکتر . (نقطه): در حالت عادی به معنای «هر کاراکتر» است. اما داخل براکت، فقط به معنای خودِ کاراکتر «نقطه» است.
  • کاراکتر * (ستاره): در حالت عادی به معنای «صفر یا بیشتر» است. اما داخل براکت، فقط به معنای خودِ کاراکتر «ستاره» است.

مثال:

  • الگو: [^.*]
  • معنای اشتباه: «هر چیزی که با الگوی “.*” (صفر یا بیشتر از هر کاراکتر) مطابقت ندارد.»
  • معنای درست: «هر کاراکتر تکی که نه نقطه ‘.’ باشد و نه ستاره ‘*’».

تنها کاراکترهایی که داخل [] همچنان رفتار خاصی دارند (و گاهی نیاز به Escape کردن دارند) عبارتند از:

  1. ^ (اگر در ابتدا بیاید، نفی می‌کند)
  2. – (اگر بین دو کاراکتر بیاید، بازه تعریف می‌کند)
  3. ] (برای بستن کلاس)
  4. \ (برای Escape کردن موارد بالا)

آیا [^] کاراکتر خط جدید (Newline) را مطابقت می‌دهد؟ (یک چالش رایج)

پاسخ کوتاه و مستقیم: بله، معمولاً مطابقت می‌دهد.

این یک تفاوت بسیار مهم بین اپراتور نفی [^…] و متاکاراکتر «نقطه» (.) است:

  • نقطه (.): در اکثر موتورهای Regex، نقطه به طور پیش‌فرض با هر کاراکتری مطابقت دارد به جز کاراکتر خط جدید (Newline یا \n). (مگر اینکه حالت خاص s یا dotall فعال باشد).
  • کلاس نفی شده ([^…]): این ساختار هیچ استثنای پیش‌فرض ندارد. وقتی شما می‌گویید [^a]، منظور شما «هر کاراکتری به جز ‘a’» است و این شامل کاراکتر خط جدید (\n)، تب (\t) و هر کاراکتر دیگری می‌شود.

مثال:

  • الگو: [^a]
  • رشته: “b\na”
  • نتایج مطابقت:
    1. ‘b’
    2. ‘\n’ (کاراکتر خط جدید)

این رفتار می‌تواند در پردازش متن‌های چند خطی بسیار مفید باشد، اما اگر از آن آگاه نباشید، ممکن است نتایجی غیرمنتظره دریافت کنید.

 مباحث پیشرفته: ترکیب [^] با سایر اپراتورها

درک نحوه ترکیب کلاس نفی شده با سایر دستورات، مرز بین استفاده ابتدایی و حرفه‌ای از Regex است. این الگوها می‌توانند بسیار بهینه و سریع باشند.

استفاده همزمان از نفی و Quantifiers (مانند [^”]+ برای تطبیق متن داخل کوتیشن)

این یکی از پرکاربردترین و کارآمدترین الگوها در Regex است. فرض کنید می‌خواهیم تمام متن داخل یک جفت دابل کوتیشن (“) را استخراج کنیم.

  • الگوی ناکارآمد (Greedy): اگر از الگوی “.*” استفاده کنیم، به دلیل رفتار «حریصانه» (Greedy) اپراتور *، الگو از اولین ” تا آخرین ” در رشته را مطابقت می‌دهد. برای مثال، در رشته “A” and “B”، کل عبارت A” and “B را به عنوان یک نتیجه برمی‌گرداند.
  • الگوی بهینه (Nagation + Quantifier): الگوی صحیح “[^”]+” است.
  • تحلیل الگو:
    1. “: با کاراکتر کوتیشن آغازی مطابقت دارد.
    2. [^”]: با هر کاراکتر تکی به جز کوتیشن (“) مطابقت دارد.
    3. +: (Quantifier) می‌گوید کاراکتر قبلی (یعنی “هر چیزی جز کوتیشن”) را یک یا چند بار تکرار کن.
    4. “: با کاراکتر کوتیشن پایانی مطابقت دارد.

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

 تفاوت رفتار [^] در موتورهای مختلف Regex (JavaScript vs. PCRE)

در مورد خودِ اپراتور [^…] (کلاس کاراکتر نفی شده)، خبر خوب این است که رفتار آن در تمام موتورهای Regex مدرن، از جمله PCRE (مورد استفاده در PHP)، JavaScript، Python، و .NET، کاملاً یکسان و استاندارد است.

این یکی از بنیادی‌ترین و قدیمی‌ترین بخش‌های عبارات منظم است و تفاوتی در نحوه تفسیر آن وجود ندارد.

نکته تفاوت: تفاوت‌هایی که گاهی مشاهده می‌شود، به خودِ [^…] مربوط نیست، بلکه به موارد زیر مربوط می‌شود:

  • تعریف موتور از «کاراکتر»: نحوه مدیریت کاراکترهای Unicode پیچیده یا astral planes می‌تواند متفاوت باشد.
  • رفتار متاکاراکترهای دیگر: برای مثال، رفتار پیش‌فرض لنگر ^ (خارج از براکت) یا متاکاراکتر . (نقطه) در مدیریت خطوط جدید، می‌تواند بین موتورها متفاوت باشد.

اما خودِ الگوی [^a] در همه جا به معنای «یک کاراکتر تکی به جز ‘a’» است.

 جایگزین‌های [^]: چه زمانی از Negative Lookaheads استفاده کنیم؟

این یک مبحث کلیدی در Regex پیشرفته است. [^…] و «نگاه به جلوی منفی» (Negative Lookahead) یا (?!…) هر دو برای نفی کردن به کار می‌روند، اما تفاوت عملکردی حیاتی دارند.

  • [^…] (کلاس نفی شده):
    • یک کاراکتر را مصرف می‌کند (Consumes).
    • فقط می‌تواند یک کاراکتر تکی (یا لیستی از کاراکترهای تکی) را بررسی کند.
    • مثال: [^a] یعنی «یک کاراکتر بگیر که ‘a’ نباشد».
  • (?!…) (نگاه به جلوی منفی):
    • کاراکتری مصرف نمی‌کند (Zero-width). این فقط یک «بررسی» یا «شرط» (Assertion) در موقعیت فعلی است.
    • می‌تواند یک رشته کامل یا الگوی پیچیده را بررسی کند.

چه زمانی از Lookahead استفاده کنیم؟

زمانی که می‌خواهید اطمینان حاصل کنید که یک دنباله از کاراکترها (و نه فقط یک کاراکتر) در ادامه وجود ندارد.

  • مثال کلاسیک: پیدا کردن کلمه foo به شرطی که bar بلافاصله بعد از آن نیاید.
    • الگوی درست: foo(?!bar)
    • این الگو با foo در “foobaz” مطابقت دارد، اما با foo در “foobar” مطابقت ندارد.
    • چرا [^…] اینجا کار نمی‌کند؟ شما نمی‌توانید الگویی مانند foo[^bar] بنویسید. این الگو معنای کاملاً متفاوتی دارد: “کلمه foo، سپس یک کاراکتر تکی که نه ‘b’، نه ‘a’ و نه ‘r’ باشد”.

جمع‌بندی

درک کاراکتر نفی [^…] یکی از قدم‌های اساسی برای تسلط بر Regex است. این ابزار به شما اجازه می‌دهد منطق جستجو را معکوس کنید؛ به جای اینکه مشخص کنید چه کاراکترهایی را می‌خواهید، به سادگی مشخص می‌کنید چه کاراکترهایی را نمی‌خواهید.

چکیده نکات کلیدی این مطلب:

  • نقش دوگانه: ^ در خارج از براکت [] به معنای «شروع خط» است، اما در ابتدای داخل براکت [^…] به معنای «نفی» است.
  • مصرف کاراکتر: [^…] یک کلاس کاراکتر است و باید دقیقاً یک کاراکتر را که در لیست ممنوعه نیست، مطابقت دهد.
  • کاراکترهای خاص: متاکاراکترهایی مانند . و * در داخل براکت، معنای خاص خود را از دست می‌دهند.
  • خط جدید (Newline): برخلاف متاکاراکتر نقطه (.)، کلاس نفی شده [^…] به طور پیش‌فرض کاراکتر خط جدید (\n) را نیز مطابقت می‌دهد.
  • جایگزین: برای نفی کردن رشته‌ها یا الگوهای کامل (و نه فقط یک کاراکتر)، باید از «نگاه به جلوی منفی» یا (?!…) استفاده کرد.

استفاده درست از این دستور، الگوهای شما را بهینه‌تر، خواناتر و بسیار کارآمدتر خواهد کرد.

author-avatar

درباره صابر رحیمی

من صابر رحیمی 2 ساله که در زمینه سئو و تولید محتوا متنی فعالیت می‌کنم هر روز در این حوزه مطالب جدید یاد می‌گیرم و اگر دوست داشتی در تلگرام، سئوکده رو دنبال کن بهم پیام بده.

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *