الهدف من هذه الدورة هو مساعدة الأشخاص الذين لم يسبق لهم كتابة برنامج قبل تعلم الكتابة. لا يوجد سبب لماذا عمال المكاتب ، وربات البيوت ، والمهندسين المحترفين وموظفي توصيل البيتزا لا ينبغي أن يكون قادرًا على الاستفادة من برامج الكمبيوتر المخصصة المصنوعة يدويًا للعمل بشكل أسرع و أذكى. لا يجب أن يستغرق الأمر "مبرمجًا محترفًا" (مهما كان) للقيام بهذه المهمة. أنت تعرف ما يجب القيام به أفضل من أي شخص آخر. تستطيع فعلها بنفسك!
(وأنا أقول هذا كشخص أمضى سنوات عديدة في كتابة برامج لأشخاص آخرين... 'مهنيا'.)
مع ذلك ، هذه ليست دورة في كيفية استخدام الكمبيوتر.
تفترض هذه الدورة أنك تعرف كيفية استخدام البرامج الشائعة وخاصة أن برنامج Microsoft Word 2007 مثبت على جهاز الكمبيوتر الخاص بك. يجب أن تعرف مهارات الكمبيوتر الأساسية مثل كيفية إنشاء مجلدات الملفات (أي الدلائل) وكيفية نقل الملفات ونسخها. ولكن إذا كنت تتساءل دائمًا عن برنامج الكمبيوتر بالفعل ، فلا بأس. سنريكم.
Microsoft Office ليس رخيصًا. ولكن يمكنك الحصول على قيمة أكبر من تلك البرامج باهظة الثمن التي قمت بتثبيتها بالفعل. هذا سبب كبير نستخدمه البصرية الأساسية
للتطبيقات ، أو VBA ، مع Microsoft Office. هناك الملايين من الأشخاص الذين يمتلكونها وعدد قليل (ربما لا أحد) يستخدم كل ما يمكنه فعله.قبل أن نذهب إلى أبعد من ذلك ، أحتاج إلى شرح شيء آخر عن VBA. في فبراير 2002 ، قامت Microsoft بمراهنة 300 مليار دولار على قاعدة تقنية جديدة تمامًا لشركتها بأكملها. أطلقوا عليه اسم .NET. منذ ذلك الحين ، قامت Microsoft بنقل قاعدتها التكنولوجية بالكامل إلى VB.NET. VBA هي أداة البرمجة الأخيرة التي لا تزال تستخدم VB6 ، التكنولوجيا المجربة والحقيقية التي تم استخدامها قبل VB.NET. (سترى العبارة "COM Based" لوصف تقنية مستوى VB6.)
VSTO و VBA
أنشأت Microsoft طريقة لكتابة برامج VB.NET لـ Office 2007. يطلق عليه أدوات Visual Studio لـ Office (VSTO). المشكلة في VSTO هي أنه يجب عليك شراء Visual Studio Professional وتعلمه. لا يزال Excel نفسه قائمًا على COM أيضًا ، ويجب أن تعمل برامج .NET مع Excel من خلال واجهة (تسمى PIA ، Primary Interop Assembly).
وبالتالي... حتى تقوم Microsoft بعملها معًا وتمنحك طريقة لكتابة البرامج التي ستعمل مع Word ولا تجعلك تنضم إلى قسم تكنولوجيا المعلومات ، لا تزال وحدات ماكرو VBA هي الطريق الصحيح.
سبب آخر لاستخدام VBA هو أنه "مخبوز بالكامل" حقًا (ليس نصف مخبوز) تطوير البرمجيات البيئة التي تم استخدامها لسنوات من قبل المبرمجين لإنشاء بعض الأنظمة الأكثر تطوراً في الوجود. لا يهم مدى ارتفاع مشاهد البرمجة الخاصة بك. يمتلك Visual Basic القوة ليأخذك إلى هناك.
ما هو الماكرو؟
ربما تكون قد استخدمت تطبيقات سطح المكتب التي تدعم ما يسمى بلغة الماكرو من قبل. تعد الماكرو تقليديا مجرد نصوص من إجراءات لوحة المفاتيح تم تجميعها مع اسم واحد حتى تتمكن من تنفيذها كلها في وقت واحد. إذا كنت تبدأ اليوم دائمًا بفتح مستند "MyDiary" الخاص بك ، وإدخال تاريخ اليوم ، وكتابة الكلمات ، "يوميات عزيزي" - لماذا لا تدع جهاز الكمبيوتر الخاص بك يقوم بذلك نيابةً عنك؟ لتكون متسقة مع البرامج الأخرى ، تطلق Microsoft VBA على لغة الماكرو أيضًا. لكنها ليست كذلك. إنها أكثر بكثير.
تتضمن العديد من تطبيقات سطح المكتب أداة برمجية تتيح لك تسجيل ماكرو "ضغط المفاتيح". في تطبيقات Microsoft ، تسمى هذه الأداة مسجل الماكرو ، ولكن النتيجة ليست ماكرو ضغط المفاتيح التقليدي. إنه برنامج VBA والفرق هو أنه لا يعيد ضغطات المفاتيح ببساطة. يمنحك برنامج VBA نفس النتيجة النهائية إن أمكن ، ولكن يمكنك أيضًا كتابة أنظمة معقدة في VBA تترك وحدات ماكرو لوحة المفاتيح البسيطة في الغبار. على سبيل المثال ، يمكنك استخدام وظائف Excel في Word باستخدام VBA. ويمكنك دمج VBA مع أنظمة أخرى مثل قواعد البيانات أو الويب أو تطبيقات البرامج الأخرى.
على الرغم من أن VBA Macro Recorder مفيد للغاية لإنشاء وحدات ماكرو لوحة مفاتيح بسيطة ، مبرمجين اكتشفوا أنه من المفيد أكثر منحهم بداية تشغيل في برامج أكثر تعقيدًا. هذا ما سنفعله.
بداية مايكروسوفت وورد 2007 مع مستند فارغ والاستعداد لكتابة برنامج.
علامة التبويب المطور في Word
أحد الأشياء الأولى التي عليك القيام بها لكتابة برنامج Visual Basic في Word 2007 هو تجد Visual Basic! الإعداد الافتراضي في Word 2007 هو عدم عرض الشريط المستخدم. لإضافة مطور انقر فوق علامة التبويب مكتب. مقر. مركز زر (الشعار في الزاوية اليسرى العليا) ثم انقر فوق خيارات Word. انقر إظهار علامة تبويب المطور في الشريط ثم انقر فوق حسنا.
عند النقر فوق مطور علامة التبويب ، لديك مجموعة جديدة كاملة من الأدوات المستخدمة لكتابة برامج VBA. سنستخدم مسجل VBA Macro Recorder لإنشاء برنامجك الأول. (إذا استمر اختفاء الشريط الذي يحتوي على جميع أدواتك ، فقد ترغب في النقر بزر الماوس الأيمن فوق الشريط والتأكد قم بتصغير الشريط لم يتم التحقق.)
انقر سجل ماكرو. قم بتسمية الماكرو الخاص بك: حول VB1 بكتابة هذا الاسم في اسم الماكرو مربع الكتابة. حدد المستند الحالي كموقع لتخزين الماكرو الخاص بك وانقر فوق موافق. انظر المثال أدناه.
(ملاحظة: إذا اخترت كافة المستندات (Normal.dotm) من القائمة المنسدلة ، سيصبح برنامج VBA التجريبي هذا ، في الواقع ، جزءًا من Word نفسه لأنه سيصبح متاحًا لكل مستند تقوم بإنشائه في Word. إذا كنت ترغب فقط في استخدام ماكرو VBA في مستند معين ، أو إذا كنت تريد أن تكون قادرًا على إرساله إلى شخص آخر ، فمن الأفضل حفظ الماكرو كجزء من المستند. Normal.dotm هو الافتراضي لذا يجب تغييره.)
مع تشغيل مسجل الماكرو ، اكتب النص "Hello World". في مستند Word الخاص بك. (سيتغير مؤشر الماوس إلى صورة مصغرة لخرطوشة الشريط لإظهار تسجيل ضغطات المفاتيح.)
(ملاحظة: Hello World مطلوب تقريبًا لـ "البرنامج الأول" لأن أول دليل برمجة في وقت مبكر لغة الحاسوب "C" استخدمته. لقد كان تقليدًا منذ ذلك الحين.)
انقر إيقاف التسجيل. أغلق Word واحفظ المستند باستخدام الاسم: حول VB1.docm. يجب عليك تحديد مستند Word تم تمكين الماكرو من حفظ كنوع اسقاط.
هذا هو! لقد كتبت الآن برنامج Word VBA. دعونا نرى كيف يبدو!
فهم ما هو برنامج VBA
إذا قمت بإغلاق Word ، فافتحه مرة أخرى وحدد حول VB1.docm ملف قمت بحفظه في الدرس السابق. إذا تم كل شيء بشكل صحيح ، يجب أن تشاهد لافتة في أعلى نافذة المستند مع تحذير أمني.
فبا والأمن
VBA حقيقي لغة برمجة. هذا يعني أن VBA يمكنه فعل أي شيء تحتاجه للقيام به. وهذا بدوره يعني أنه إذا تلقيت مستند Word يحتوي على ماكرو مضمن من بعض "الأشرار" ، فإن الماكرو يمكنه فعل أي شيء أيضًا. لذا يجب أخذ تحذير Microsoft على محمل الجد. من ناحية أخرى، أنت كتب هذا الماكرو وكل ما يفعله هو كتابة "Hello World" لذلك لا يوجد خطر هنا. انقر فوق الزر لتمكين وحدات الماكرو.
لمعرفة ما أنشأه مسجل الماكرو (وكذلك للقيام بمعظم الأشياء الأخرى التي تتضمن VBA) ، تحتاج إلى بدء تشغيل محرر Visual Basic. هناك رمز للقيام بذلك على الجانب الأيسر من شريط المطور.
أولاً ، لاحظ النافذة اليسرى. هذا يسمى مستكشف المشاريع ويقوم بتجميع الكائنات عالية المستوى (سنتحدث عنها أكثر) والتي تعد جزءًا من مشروع Visual Basic.
عند بدء تشغيل Macro Recorder ، كان لديك خيار عادي قالب أو المستند الحالي كموقع للماكرو الخاص بك. إذا قمت بتحديد عادي ، ثم NewMacros ستكون الوحدة جزءًا من عادي فرع من شاشة Project Explorer. (كان من المفترض أن تحدد الوثيقة الحالية. إذا اخترت عادي، احذف المستند وكرر التعليمات السابقة.) اختر NewMacros تحت الوحدات في مشروعك الحالي. إذا لم يكن هناك أي نافذة كود معروضة ، فانقر الشفرة تحت رأي قائمة طعام.
مستند Word كحاوية VBA
يجب أن يكون كل برنامج Visual Basic في نوع من "حاوية" ملف. في حالة وحدات ماكرو Word 2007 VBA ، تلك الحاوية هي مستند Word ('.docm'). لا يمكن تشغيل برامج Word VBA بدون Word ولا يمكنك إنشاء برامج Visual Basic مستقلة ('.exe') كما هو الحال مع Visual Basic 6 أو Visual Basic .NET. لكن هذا لا يزال يترك عالمًا كاملاً من الأشياء التي يمكنك القيام بها.
من المؤكد أن برنامجك الأول قصير ولطيف ، ولكنه سيعمل على تقديم الميزات الرئيسية لـ VBA ومحرر Visual Basic.
عادة ما يتكون مصدر البرنامج من سلسلة من الروتينات الفرعية. عندما تتخرج إلى برمجة أكثر تقدمًا ، ستكتشف أن أشياء أخرى يمكن أن تكون جزءًا من البرنامج إلى جانب الروتينات الفرعية.
يسمى هذا روتين معين حول VB1. يجب أن يقترن رأس روتين مع نهاية فرعية في الأسفل. يمكن أن يحتوي القوس على قائمة معلمات تتكون من القيم التي يتم تمريرها إلى الروتين الفرعي. لا شيء يمر هنا ، ولكن يجب أن يكونوا هناك في الفرعية بيان على أي حال. لاحقًا ، عندما ندير الماكرو ، سنبحث عن الاسم حول VB1.
يوجد بيان برنامج فعلي واحد فقط في روتين:
اختيار. نص TypeText: = "Hello World!"
الأشياء والأساليب والخصائص
يحتوي هذا البيان على الثلاثة الكبار:
- شيء
- طريقة
- ملكية
يضيف البيان بالفعل النص "Hello World". إلى محتويات المستند الحالي.
المهمة التالية هي تشغيل برنامجنا عدة مرات. تمامًا مثل شراء سيارة ، من الجيد أن تقودها لبعض الوقت حتى تشعر بالراحة قليلاً. نفعل ذلك بعد ذلك.
البرامج والوثائق
لدينا نظامنا المجيد والمعقد... يتكون من بيان برنامج واحد... ولكن الآن نريد تشغيله. إليك ما يدور حوله.
هناك مفهوم واحد يجب تعلمه هنا وهو مهم جدًا وغالبًا ما يخلط بين التوقيت الأول: الفرق بين برنامج و ال المستند. هذا المفهوم أساسي.
يجب أن يتم تضمين برامج VBA في ملف مضيف. في Word ، المضيف هو المستند. هذا في مثالنا حول VB1.docm. يتم حفظ البرنامج بالفعل داخل المستند.
على سبيل المثال ، إذا كان هذا Excel ، فإننا نتحدث عن برنامج و ال جدول. في Access ، برنامج و ال قاعدة البيانات. حتى في تطبيق Visual Basic Windows المستقل ، سيكون لدينا برنامج و شكل.
(ملاحظة: هناك اتجاه في البرمجة للإشارة إلى جميع الحاويات عالية المستوى على أنها "وثيقة". هذا هو الحال على وجه التحديد عندما XML... تقنية أخرى قادمة... يتم إستخدامه. لا تدعه يربكك. على الرغم من أنها غير دقيقة ، يمكنك التفكير في "المستندات" على أنها تقريبًا مثل "الملفات".)
يوجد... اممم... حول ثلاث طرق رئيسية لتشغيل ماكرو VBA.
- يمكنك تشغيله من مستند Word.
(ملاحظة: هناك فئتان فرعيتان لتحديد وحدات الماكرو من قائمة الأدوات أو الضغط على Alt-F8 فقط. إذا قمت بتعيين الماكرو إلى اختصار شريط الأدوات أو لوحة المفاتيح ، فهذه طريقة أخرى.)) - يمكنك تشغيله من المحرر باستخدام أيقونة التشغيل أو قائمة التشغيل.
- يمكنك خطوة واحدة من خلال البرنامج في وضع التصحيح.
يجب أن تجرب كل طريقة من هذه الطرق فقط لتصبح مرتاحًا مع واجهة Word / VBA. عند الانتهاء ، سيكون لديك مستند كامل مليء بتكرارات "Hello World!"
تشغيل البرنامج من Word سهل إلى حد ما. فقط حدد الماكرو بعد النقر فوق دقيق أيقونة تحت رأي التبويب.
لتشغيله من المحرر ، قم أولاً بفتح محرر Visual Basic ثم انقر فوق رمز التشغيل أو حدد تشغيل من القائمة. هنا حيث قد يصبح الاختلاف بين المستند والبرنامج مربكًا للبعض. إذا قمت بتصغير المستند أو ربما تم ترتيب النوافذ الخاصة بك بحيث يقوم المحرر بتغطيته ، يمكنك النقر فوق رمز التشغيل مرارًا وتكرارًا ولا يبدو أن شيئًا يحدث. لكن البرنامج يعمل! قم بالتبديل إلى المستند مرة أخرى وانظر.
من المحتمل أن تكون خطوة واحدة من خلال البرنامج هي تقنية حل المشكلات الأكثر فائدة. يتم ذلك أيضًا من محرر Visual Basic. لتجربة هذا ، اضغط على F8 أو اختر خطوة الى من تصحيح قائمة طعام. العبارة الأولى في البرنامج الفرعية يتم إبراز البيان. يؤدي الضغط على F8 إلى تنفيذ كشوف البرنامج واحدًا تلو الآخر حتى انتهاء البرنامج. يمكنك أن ترى بالضبط متى تتم إضافة النص إلى المستند بهذه الطريقة.
هناك الكثير من تقنيات التصحيح الأكثر دقة مثل "نقاط التوقف" ، وفحص كائنات البرنامج في "النافذة الفورية" ، واستخدام "نافذة المراقبة". ولكن في الوقت الحالي ، ما عليك سوى الانتباه إلى أن هذه تقنية تصحيح أساسية ستستخدمها كمبرمج.
البرمجة الشيئية
درس الصف التالي هو كل شيء البرمجة الشيئية.
"وتحتت!" (أسمعك تئن) "أريد فقط كتابة البرامج. لم أقم بالتسجيل لأصبح عالم كمبيوتر! "
لا تخافوا! هناك سببان لماذا هذه خطوة عظيمة.
أولاً ، في بيئة البرمجة اليوم ، لا يمكنك ببساطة أن تكون مبرمجًا فعالًا دون فهم مفاهيم البرمجة الشيئية. يتألف حتى برنامج "Hello World" البسيط من سطر واحد من كائن وطريقة وخاصية. في رأيي ، عدم فهم الأشياء هو أكبر مشكلة يعاني منها المبرمجون. لذا سنواجه الوحش في الأمام!
ثانيًا ، سنجعل هذا غير مؤلم قدر الإمكان. لن نخلط بينك وبين الكثير من مصطلحات علوم الكمبيوتر.
ولكن بعد ذلك مباشرة ، سنقفز سريعًا إلى كتابة كود البرمجة مع درس نطور فيه ماكرو VBA يمكنك استخدامه على الأرجح! نحن نتقن هذا البرنامج أكثر قليلاً في الدرس التالي وننتهي من خلال توضيح كيفية بدء استخدام VBA مع العديد من التطبيقات في وقت واحد.