استخدام Grep لعرض الخطوط المحيطة بالمطابقات

Bash

إتقان Grep لعمليات البحث السياقية

عند العمل مع الملفات النصية، غالبًا ما يكون من الضروري البحث عن أنماط أو سلاسل محددة. يعد الأمر `grep` في Unix/Linux أداة قوية لهذا الغرض. ومع ذلك، في بعض الأحيان لا يكون مجرد العثور على التطابق كافيًا؛ قد تحتاج أيضًا إلى رؤية الخطوط المحيطة بالنمط المطابق لفهم السياق.

في هذه المقالة، سوف نستكشف كيفية استخدام `grep` ليس فقط للعثور على الأنماط المطلوبة ولكن أيضًا لعرض الأسطر الخمسة السابقة واللاحقة لكل تطابق. هذه التقنية لا تقدر بثمن لتصحيح الأخطاء، وتحليل السجل، ومهام استخراج البيانات.

يأمر وصف
grep -C يعرض الأسطر المطابقة مع العدد المحدد من أسطر السياق قبل كل مطابقة وبعدها.
#!/bin/bash يحدد أنه يجب تشغيل البرنامج النصي في بيئة Bash Shell.
import re يستورد مكتبة التعبير العادي في بايثون، والتي تسمح بمطابقة الأنماط داخل السلاسل.
max() تُرجع أكبر قيم الإدخال المستخدمة هنا لتجنب المؤشرات السالبة.
min() تُرجع أصغر قيم الإدخال المستخدمة هنا لتجنب الفهارس التي تتجاوز طول القائمة.
enumerate() يضيف عدادًا إلى عنصر قابل للتكرار، وهو مفيد للحصول على الفهرس والقيمة في الحلقة.
sys.argv يوفر الوصول إلى وسيطات سطر الأوامر التي تم تمريرها إلى برنامج Python النصي.

فهم البرامج النصية للبحث السياقي Grep

النص الأول، المكتوب بلغة Bash، يستفيد من أمر للبحث عن الأنماط داخل الملف وعرض الخطوط المحيطة بكل تطابق. ال يعد الخيار قويًا بشكل خاص، لأنه يسمح للمستخدمين بتحديد عدد أسطر السياق التي سيتم عرضها قبل وبعد كل مطابقة. في هذا البرنامج النصي، يوفر المستخدم نمط بحث واسم ملف كوسائط. ثم يتم تنفيذ البرنامج النصي ، أين -C 5 يروي لإظهار الأسطر الخمسة قبل وبعد كل سطر مطابق. يعد هذا الأسلوب مباشرًا وفعالًا للعثور بسرعة على التطابقات ووضعها في سياق الملفات النصية الكبيرة، مما يجعله مثاليًا لمهام مثل تحليل السجل أو تصحيح الأخطاء.

يقدم النص الثاني، المكتوب بلغة بايثون، نهجًا أكثر برمجية لتحقيق نفس الهدف. يستخدم وحدة لمطابقة التعبير العادي و للتعامل مع وسيطات سطر الأوامر. ال تقوم الوظيفة بقراءة الملف في قائمة الأسطر وتكرارها، والتحقق من تطابق كل سطر باستخدام re.search. عند العثور على تطابق، فإنه يقوم بحساب مؤشرات البداية والنهاية لتشمل العدد المحدد من الأسطر قبل وبعد المطابقة، مع ضمان بقائها ضمن حدود القائمة باستخدام و المهام. يوفر هذا البرنامج النصي المرونة ويمكن توسيعه أو تعديله بسهولة ليناسب احتياجات محددة، مثل تغيير نطاق السياق أو التكامل مع مهام معالجة البيانات الأخرى.

كيفية استخدام Grep لعمليات البحث السياقية

Bash Script لعمليات البحث السياقية

#!/bin/bash
# Usage: ./script.sh pattern filename
pattern=$1
filename=$2
grep -C 5 "$pattern" "$filename"

استخدام Grep مع خيارات السياق

برنامج Python النصي لتقليد Grep مع السياق

import sys
import re
def grep_context(pattern, filename, context=5):
    with open(filename, 'r') as file:
        lines = file.readlines()
    for i, line in enumerate(lines):
        if re.search(pattern, line):
            start = max(i - context, 0)
            end = min(i + context + 1, len(lines))
            for l in lines[start:end]:
                print(l, end='')
if __name__ == "__main__":
    pattern = sys.argv[1]
    filename = sys.argv[2]
    grep_context(pattern, filename)

استكشاف خيارات Grep المتقدمة لعمليات البحث السياقية

أبعد من الأساسية الخيار، عدة متقدمة توفر الخيارات المزيد من التحكم والمرونة عند البحث عن الأنماط وعرض الخطوط المحيطة. أحد هذه الخيارات هو ، والذي يعرض عددًا محددًا من الأسطر بعد كل مباراة. يمكن أن يكون هذا مفيدًا بشكل خاص عندما يكون السياق الذي يلي المطابقة أكثر أهمية لتحليلك. بصورة مماثلة، grep -B يعرض الخطوط قبل كل مباراة، مما يوفر رؤية مركزة للسياق الرئيسي. ومن خلال الجمع بين هذه الخيارات، يمكنك تخصيص الإخراج ليناسب متطلباتك بدقة.

ميزة قوية أخرى هي استخدام التعبيرات العادية داخل . ومن خلال الاستفادة من التعبيرات العادية، يمكنك إجراء عمليات بحث أكثر تعقيدًا تتجاوز مجرد مطابقة السلسلة البسيطة. على سبيل المثال، باستخدام الخيار مع يسمح باستخدام التعبيرات العادية الموسعة، مما يوفر قدرة أكثر شمولاً على مطابقة الأنماط. يعد هذا مفيدًا في السيناريوهات التي تحتاج فيها إلى مطابقة الأنماط ذات الأطوال أو التنسيقات المختلفة. بالإضافة إلى ذلك، grep يدعم الخيار، الذي يسلط الضوء على الأنماط المتطابقة في المخرجات، مما يسهل التعرف على التطابقات بصريًا داخل كتل كبيرة من النص.

  1. كيف يمكنني عرض الخطوط فقط بعد كل مباراة باستخدام grep؟
  2. استخدم ال الخيار متبوعًا بعدد الخطوط التي تريد عرضها بعد كل مباراة.
  3. كيف يمكنني إظهار الخطوط قبل المباراة مع grep؟
  4. ال يتيح لك الخيار عرض الخطوط قبل كل مباراة متبوعة بعدد الخطوط.
  5. هل يمكنني دمج الخيارات لإظهار الخطوط قبل المباراة وبعدها؟
  6. نعم الجمع و ستعرض الخيارات الخطوط قبل وبعد كل مباراة.
  7. ماذا يفعل خيار grep --color؟
  8. ال يسلط الخيار الضوء على الأنماط المتطابقة في المخرجات، مما يسهل رؤيتها.
  9. كيف يمكنني استخدام التعبيرات العادية مع grep؟
  10. استخدم ال خيار لتمكين التعبيرات العادية الموسعة لمطابقة الأنماط الأكثر تعقيدًا.
  11. هل هناك طريقة للحد من عدد التطابقات التي يعرضها grep؟
  12. نعم الخيار متبوعًا برقم يحد من عدد التطابقات المعروضة.
  13. هل يمكنني إجراء عمليات بحث grep غير حساسة لحالة الأحرف؟
  14. باستخدام الخيار يجعل البحث غير حساس لحالة الأحرف.
  15. كيف أبحث عن أنماط في ملفات متعددة باستخدام grep؟
  16. يمكنك توفير أسماء ملفات متعددة أو استخدام أحرف البدل مع للبحث عبر عدة ملفات في وقت واحد.

استكشاف خيارات Grep المتقدمة لعمليات البحث السياقية

أبعد من الأساسية الخيار، عدة متقدمة توفر الخيارات المزيد من التحكم والمرونة عند البحث عن الأنماط وعرض الخطوط المحيطة. أحد هذه الخيارات هو ، والذي يعرض عددًا محددًا من الأسطر بعد كل مباراة. يمكن أن يكون هذا مفيدًا بشكل خاص عندما يكون السياق الذي يلي المطابقة أكثر أهمية لتحليلك. بصورة مماثلة، grep -B يعرض الخطوط قبل كل مباراة، مما يوفر رؤية مركزة للسياق الرئيسي. ومن خلال الجمع بين هذه الخيارات، يمكنك تخصيص الإخراج ليناسب متطلباتك بدقة.

ميزة قوية أخرى هي استخدام التعبيرات العادية داخل . ومن خلال الاستفادة من التعبيرات العادية، يمكنك إجراء عمليات بحث أكثر تعقيدًا تتجاوز مجرد مطابقة السلسلة البسيطة. على سبيل المثال، باستخدام الخيار مع يسمح باستخدام التعبيرات العادية الموسعة، مما يوفر قدرة أكثر شمولاً على مطابقة الأنماط. يعد هذا مفيدًا في السيناريوهات التي تحتاج فيها إلى مطابقة الأنماط ذات الأطوال أو التنسيقات المختلفة. بالإضافة إلى ذلك، grep يدعم الخيار، الذي يسلط الضوء على الأنماط المتطابقة في المخرجات، مما يسهل التعرف على التطابقات بصريًا داخل كتل كبيرة من النص.

من خلال الجمع بين الخيارات ولغات البرمجة النصية مثل ، يمكنك البحث بكفاءة عن الأنماط وعرض خطوط السياق المحيطة في ملفات نصية. تعمل هذه الأساليب على تحسين قدرتك على تحليل البيانات وتفسيرها، مما يجعلها أدوات قيمة لتحليل السجل وتصحيح الأخطاء ومهام استخراج البيانات.