Skip to main content

كيفية حماية الخلايا بناءً على التاريخ في Excel؟

Author: Xiaoyang Last Modified: 2025-05-30

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

protect cells based on date

حماية جميع الصفوف باستثناء صف تاريخ اليوم باستخدام كود VBA

حماية جميع الصفوف التي مر عليها التاريخ باستخدام كود VBA


arrow blue right bubble حماية جميع الصفوف باستثناء صف تاريخ اليوم باستخدام كود VBA

للسماح فقط بتعديل الصف الذي يساوي تاريخ اليوم، يمكن أن يساعدك الكود التالي، يرجى القيام بما يلي:

1. انقر بزر الماوس الأيمن على تبويب الورقة التي تريد حماية الخلايا فيها بناءً على التاريخ، ثم اختر عرض الكود من قائمة السياق. في نافذة Microsoft Visual Basic for Applications المنبثقة، يرجى نسخ ولصق الكود التالي في الوحدة الفارغة:

كود VBA: حماية جميع الصفوف باستثناء صف تاريخ اليوم:

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
'Updateby Extendoffice 20161025
    If Range("E" & Selection.Row).Value <> Date Then
        ActiveSheet.Protect Password:="111111"
        MsgBox "Only today's date row can be edited!", vbInformation, "Kutools for Excel"
    ElseIf Range("E" & Selection.Row).Value = Date Then
        ActiveSheet.Unprotect Password:="111111"
        ActiveSheet.EnableSelection = xlNoRestrictions
    End If
End Sub

click View Code and paste the code intot he module

ملاحظة: في الكود أعلاه، الحرف E هو رأس العمود الذي يحتوي على التاريخ، وكلمة المرور “111111” هي لحماية هذه الورقة. يمكنك تغييرها حسب الحاجة.

2. ثم احفظ وأغلق نافذة الكود هذه.

(1.) إذا نقرت على خلايا أخرى خارج صف تاريخ اليوم، ستظهر نافذة منبثقة لتذكيرك بأن الخلية لا يمكن تعديلها، انظر لقطة الشاشة:

If click other cells beyond today’s date row, an prompt box will pop out to remind you the cell can’t be edited

(2.) إذا نقرت وقمت بتحرير الصف الذي يساوي تاريخ اليوم، سيتم التعديل بنجاح، انظر لقطة الشاشة:

If click and edit the row equals today’s date, it will be modified

a screenshot of kutools for excel ai

اكتشف سحر Excel مع Kutools AI

  • التنفيذ الذكي: قم بعمليات الخلية، وتحليل البيانات، وإنشاء المخططات - كل ذلك يتم من خلال أوامر بسيطة.
  • الصيغ المخصصة: قم بإنشاء صيغ مصممة خصيصًا لتسهيل سير عملك.
  • برمجة VBA: كتابة وتطبيق أكواد VBA بسهولة.
  • تفسير الصيغ: فهم الصيغ المعقدة بسهولة.
  • ترجمة النصوص: تجاوز الحواجز اللغوية داخل جداول البيانات الخاصة بك.
عزز قدرات Excel لديك باستخدام أدوات تعمل بالذكاء الاصطناعي. قم بالتنزيل الآن وعش تجربة الكفاءة كما لم يحدث من قبل!

arrow blue right bubble حماية جميع الصفوف التي مر عليها التاريخ باستخدام كود VBA

إذا كنت بحاجة إلى حماية جميع الصفوف التي مر عليها التاريخ والسماح فقط بتعديل صفوف تاريخ اليوم والتواريخ المستقبلية، يرجى تطبيق الكود التالي لـ VBA:

1. انقر بزر الماوس الأيمن على تبويب الورقة التي تريد حماية الخلايا فيها بناءً على التاريخ، ثم اختر عرض الكود من قائمة السياق. في نافذة Microsoft Visual Basic for Applications المنبثقة، يرجى نسخ ولصق الكود التالي في الوحدة الفارغة:

كود VBA: حماية جميع الصفوف التي مر عليها التاريخ:

Private Sub Worksheet_Change(ByVal Target As Excel.Range)
'Updateby Extendoffice 20161025
  Dim xRow As Long
  xRow = 2
  ThisWorkbook.ActiveSheet.Unprotect Password:="111111"
  ThisWorkbook.ActiveSheet.Cells.Locked = False
  Do Until IsEmpty(Cells(xRow, 5))
    If Cells(xRow, 5) < Date Then
      Rows(xRow).Locked = True
    End If
    xRow = xRow + 1
  Loop
  ThisWorkbook.ActiveSheet.Protect Password:="111111"
End Sub

click View Code and paste the code intot he module

ملاحظة: في الكود أعلاه، الرقم 5 هو رقم العمود الذي يحتوي على التاريخ، وكلمة المرور “111111” هي لحماية هذه الورقة. يمكنك تغييرها حسب الحاجة.

3. ثم احفظ وأغلق نافذة الكود هذه.

(1.) إذا نقرت على الخلايا التي مر عليها التاريخ، ستظهر نافذة منبثقة لتذكيرك بأن الخلية لا يمكن تعديلها، انظر لقطة الشاشة:

If click the cells date has passed, an prompt box will pop out to remind the cell can’t be edited

(2.) إذا نقرت على الخلية الموجودة في الصفوف لمحاولة تغيير القيم في تاريخ اليوم أو التواريخ المستقبلية، سيتم التعديل بنجاح، انظر لقطة الشاشة:

If click the cell of rows to try to change the values in today’s date or future date, it will be modified

أفضل أدوات الإنتاجية لمكتب العمل

🤖 Kutools AI Aide: أحدث ثورة في تحليل البيانات من خلال: التنفيذ الذكي |توليد الشيفرة |إنشاء الصيغ المخصصة |تحليل البيانات وتوليد الرسوم البيانية |استدعاء الوظائف المحسنة
الميزات الشائعة: البحث، تمييز أو وضع علامة على المكررات | حذف الصفوف الفارغة | دمج الأعمدة أو العنوان دون فقدان البيانات | تقريب ...
بحث متقدم: بحث V متعدد المعايير | بحث V متعدد القيم | بحث في عدة ورقات | مطابقة غامضة ....
قائمة منسدلة متقدمة: إنشاء قائمة منسدلة بسرعة | قائمة منسدلة تابعة | قائمة منسدلة متعددة الاختيار ....
إدارة الأعمدة: إضافة عدد محدد من الأعمدة | نقل الأعمدة | تبديل حالة إظهار الأعمدة المخفية | مقارنة النطاق والأعمدة ...
ميزات مميزة: التركيز على الشبكة | عرض التصميم | شريط الصيغ المحسن | أدوات المصنف & أدوات الورقة العمل | مكتبة النص التلقائي (Auto Text) | منتقي التاريخ | دمج البيانات | تشفير/فك تشفير الخلايا | إرسال البريد الإلكتروني حسب القائمة | مرشح متقدم | تصفية خاصة (تصفية الخلايا التي تحتوي على خط عريض/مائل/يتوسطه خط...) ...
أفضل15 مجموعة أدوات:12 أداة نصية (إضافة نص، حذف الأحرف المحددة، ...) | أكثر من50 نوع من الرسوم البيانية (مخطط جانت، ...) | أكثر من40 صيغة عملية (حساب العمر بناءً على تاريخ الميلاد، ...) |19 أداة إدراج (إدراج رمز الاستجابة السريعة، إدراج صورة من المسار، ...) |12 أداة تحويل (تحويل إلى كلمات، تحويل العملة، ...) |7 أدوات دمج وتقسيم (دمج متقدم للصفوف، تقسيم الخلايا، ...) | ... والمزيد

عزز مهاراتك في Excel مع Kutools لـ Excel، واختبر الكفاءة كما لم يحدث من قبل. Kutools لـ Excel يقدم أكثر من300 ميزة متقدمة لزيادة الإنتاجية وتوفير وقت الحفظ. انقر هنا للحصول على الميزة التي تحتاجها أكثر...


Office Tab يقدم واجهة التبويب لـ Office، ويجعل عملك أسهل بكثير

  • تمكين تحرير وقراءة المستندات عبر التبويبات في Word وExcel وPowerPoint.
  • افتح وأنشئ عدة مستندات في تبويبات جديدة ضمن نفس النافذة، بدلاً من فتحها في نوافذ منفصلة.
  • يزيد إنتاجيتك بنسبة50%، ويقلل مئات النقرات بالماوس يومياً!