كيفية التنقل عبر المصنفات في دليل ونسخ البيانات إلى ورقة عمل رئيسية في Excel؟
لنفترض أن لديك عدة مصنفات Excel في مجلد وتحتاج إلى التنقل عبر جميع هذه الملفات لنسخ البيانات من نطاق معين في ورقة عمل متسقة (مثل Sheet1) إلى ورقة عمل رئيسية. يوفر هذا الدليل حلاً تفصيليًا باستخدام VBA لتبسيط هذه العملية في Excel.
التنقل عبر المصنفات في دليل ونسخ البيانات إلى ورقة عمل رئيسية باستخدام كود VBA
التنقل عبر الملفات في دليل ونسخ البيانات إلى ورقة عمل رئيسية باستخدام كود VBA
إذا كنت تريد نسخ البيانات من النطاق A1:D4 في جميع أوراق العمل Sheet1 للمصنفات الموجودة في مجلد معين ولصقها في ورقة عمل رئيسية، يرجى اتباع الخطوات التالية.
1. في المصنف الذي ستقوم بإنشاء ورقة عمل رئيسية فيه، اضغط على مفتاحي Alt + F11 لفتح نافذة Microsoft Visual Basic for Applications.
2. في نافذة Microsoft Visual Basic for Applications، انقر فوق إدراج > وحدة. ثم قم بنسخ الكود التالي الخاص بـ VBA إلى نافذة الكود.
كود VBA: التنقل عبر الملفات في مجلد ونسخ البيانات إلى ورقة عمل رئيسية
Sub Merge2MultiSheets()
Dim xRg As Range
Dim xSelItem As Variant
Dim xFileDlg As FileDialog
Dim xFileName, xSheetName, xRgStr As String
Dim xBook, xWorkBook As Workbook
Dim xSheet As Worksheet
On Error Resume Next
Application.DisplayAlerts = False
Application.EnableEvents = False
Application.ScreenUpdating = False
xSheetName = "Sheet1"
xRgStr = "A1:D4"
Set xFileDlg = Application.FileDialog(msoFileDialogFolderPicker)
With xFileDlg
If .Show = -1 Then
xSelItem = .SelectedItems.Item(1)
Set xWorkBook = ThisWorkbook
Set xSheet = xWorkBook.Sheets("New Sheet")
If xSheet Is Nothing Then
xWorkBook.Sheets.Add(after:=xWorkBook.Worksheets(xWorkBook.Worksheets.Count)).Name = "New Sheet"
Set xSheet = xWorkBook.Sheets("New Sheet")
End If
xFileName = Dir(xSelItem & "\*.xlsx", vbNormal)
If xFileName = "" Then Exit Sub
Do Until xFileName = ""
Set xBook = Workbooks.Open(xSelItem & "\" & xFileName)
Set xRg = xBook.Worksheets(xSheetName).Range(xRgStr)
xRg.Copy xSheet.Range("A65536").End(xlUp).Offset(1, 0)
xFileName = Dir()
xBook.Close
Loop
End If
End With
Application.DisplayAlerts = True
Application.EnableEvents = True
Application.ScreenUpdating = True
End Subملاحظة:
3. اضغط على مفتاح F5 لتشغيل الكود.
4. في نافذة التصفح التي ستفتح، يرجى تحديد المجلد الذي يحتوي على الملفات التي ستنقل بينها، ثم انقر فوق زر موافق. شاهد الصورة:

ثم يتم إنشاء ورقة عمل رئيسية باسم “New Sheet” في نهاية المصنف الحالي. وستكون البيانات في النطاق A1:D4 لجميع أوراق العمل Sheet1 في المجلد المحدد مدرجة داخل الورقة.
مقالات ذات صلة:
أفضل أدوات زيادة الإنتاجية لمجموعة Office
عزز مهاراتك في Excel مع Kutools لـ Excel، وتمتع بكفاءة غير مسبوقة. يقدم Kutools لـ Excel أكثر من300 ميزة متقدمة لتعزيز الإنتاجية وتوفير وقت الحفظ. انقر هنا للحصول على الميزة التي تحتاجها أكثر...
Office Tab يجلب تجربة التبويبات إلى Office، ويجعل عملك أسهل بكثير
- فعّل تحرير وقراءة المستندات عبر التبويبات في Word وExcel وPowerPoint
- افتح وأنشئ مستندات متعددة في تبويبات جديدة ضمن نفس النافذة، بدلاً من فتحها في نوافذ جديدة.
- يمنحك زيادة إنتاجية تصل إلى50% ويوفر عليك مئات النقرات يومياً!