أنشئ مكتبة برمجة تطبيقات يمكنك استخدامها لإزالة الصفوف المكرّرة في بيانات جدول البيانات.
الأهداف
- أعِدّ النص البرمجي.
- شغِّل النص البرمجي.
المتطلبات الأساسية
لاستخدام هذا النموذج، ستحتاج إلى المتطلّبات الأساسية التالية:
- حساب Google (قد تتطلب حسابات Google Workspace موافقة المشرف).
- متصفح ويب يمكنه الوصول إلى الإنترنت.
إعداد النص البرمجي
لإنشاء المكتبة، يجب اتّباع الخطوات التالية:
- سجِّل الدخول إلى حسابك على Google.
- لفتح محرِّر النصوص البرمجية، انتقِل إلى script.google.com.
- في أعلى يمين الصفحة، انقر على مشروع جديد.
احذف أي رمز في أداة تعديل النصوص البرمجية والصقه في ما يلي.
انقر على "حفظ" .
في أعلى يمين الصفحة، انقر على مشروع بلا عنوان.
أدخِل اسمًا للنص البرمجي إزالة الصفوف المكرّرة وانقر على إعادة تسمية.
انقر على نشر > نشر جديد.
بجانب اختيار النوع، انقر على "تفعيل أنواع النشر" > المكتبة.
أدخِل وصفًا للمكتبة، مثل إزالة الصفوف المكرّرة. يمكن لأي شخص لديه إمكانية الوصول إلى المكتبة الاطّلاع على هذا الوصف.
انقر على نشر.
على يمين الصفحة، انقر على إعدادات المشروع .
ضمن أرقام التعريف، انسخ رقم تعريف النص البرمجي لاستخدامه في خطوة لاحقة.
تشغيل النص البرمجي
لاستخدام مكتبة، يجب أن يكون لديك على الأقل أذونات عرض لمشروع "برمجة تطبيقات Google". منذ إنشاء المكتبة، أصبحت لديك الأذونات المطلوبة لاستخدامها. إذا كنت تريد السماح لمستخدمين آخرين باستخدام المكتبة، يمكنك منحهم الإذن بالاطّلاع على مشروع "برمجة تطبيقات Google".
لاستخدام المكتبة، يُرجى اتّباع الخطوات التالية:
- افتح جدول بيانات في "جداول بيانات Google" يحتوي على بيانات بصفوف مكرّرة. لاستخدام نموذج جدول بيانات، أنشئ نسخة من جدول بيانات نماذج الصفوف المكررة.
- انقر على الإضافات > برمجة التطبيقات.
- إلى جانب المكتبات، انقر على "إضافة مكتبة" .
- في القسم رقم تعريف النص البرمجي، الصِق رقم تعريف النص البرمجي من مشروع "برمجة تطبيقات Google" في المكتبة الذي نسخته في القسم السابق.
- انقر على بحث.
- في قسم الإصدار، اختَر 1.
- انقر على إضافة.
احذف أي رمز في أداة تعديل النصوص البرمجية والصقه في ما يلي.
function runLibrary() { Removeduplicaterows.removeDuplicates(); }
في القائمة المنسدلة للدوال، اختَر runLibrary.
انقر على تشغيل.
ارجع إلى جدول البيانات لعرض البيانات المحدّثة دون صفوف مكررة.
مراجعة الرمز
لمراجعة رمز برمجة التطبيقات لهذا الحل، انقر على عرض رمز المصدر أدناه:
عرض رمز المصدر
أولاً، يُجري النص اتصالاً واحدًا لجدول البيانات لاسترداد جميع البيانات. يمكنك اختيار قراءة الورقة صفًا تلو الآخر، ولكن عمليات JavaScript أسرع إلى حدّ كبير من التواصل مع خدمات أخرى مثل "جداول البيانات". كلما قل عدد المكالمات التي تجريها، زادت سرعة سيرها. هذا مهم لأن الحد الأقصى لوقت التشغيل لكل عملية تنفيذ للنص البرمجي هو 6 دقائق.
المتغير data
هو مصفوفة ثنائية الأبعاد في JavaScript تحتوي على كل القيم في ورقة البيانات. newData
هي مصفوفة فارغة يضع فيها النص البرمجي جميع الصفوف غير المكرّرة.
تتكرّر حلقة for
الأولى فوق كل صف في الصفيف الثنائي الأبعاد
data
. بالنسبة إلى كل صف، يختبر التكرار الحلقي الثاني ما إذا كان هناك صف آخر
ببيانات مطابقة موجودًا مسبقًا في صفيف newData
. إذا لم يكن الصف مكرّرًا، سيتم دفع الصف إلى صفيف newData
.
أخيرًا، يحذف النص البرمجي المحتوى الحالي من الورقة ويدرج
محتوى صفيف newData
.
التعديلات
يمكنك تعديل المكتبة بالشكل الذي تريده على النحو الذي تريده. فيما يلي تعديل اختياري.
إزالة صفوف بها بيانات مطابقة في بعض الأعمدة
بدلاً من إزالة الصفوف المتطابقة تمامًا، قد ترغب في إزالة الصفوف التي تحتوي على بيانات متطابقة في عمود واحد أو عمودين فقط. للقيام بذلك، يمكنك تغيير العبارة الشرطية.
في نموذج الرمز، حدِّث السطر التالي:
if(row.join() == newData[j].join()){ duplicate = true; }
استبدل السطر بالتعليمة البرمجية التالية:
if(row[0] == newData[j][0] && row[1] == newData[j][1]){ duplicate = true; }
تعثر العبارة الشرطية أعلاه على تكرارات في كل مرة يحتوي فيها صفان على نفس البيانات في العمودين الأول والثاني من الورقة.
المساهمون
أنشأ هذا النموذج "رومين فيالارد"، وهو خبير في المطوّرين لدى Google. يمكنك متابعة "روماين" على Twitter على @romain_vialard.
تحتفظ Google بهذا النموذج بمساعدة خبراء التطوير في Google.