VBA to Open excel and Break links

12Rev79

New Member
Joined
Mar 2, 2021
Messages
46
Office Version
  1. 365
  2. 2010
Platform
  1. Windows
Hi Experts,

I have a number of of Excel workbook in my folder C:\Desktop\Fabrication
Is there a way of creating a command button from my Extract1.xlsb to automate Open each workbook in the folder and break links, save in the same folder and close up to the last workbook?
My workbooks has link to another Excel workbook that I want to be remove.

Please if you may share the code.

Thanks in advance and I appreciate your help.
12Rev79
 

Excel Facts

Using Function Arguments with nested formulas
If writing INDEX in Func. Arguments, type MATCH(. Use the mouse to click inside MATCH in the formula bar. Dialog switches to MATCH.
The following code will prompt the user to select a folder, then it loops through each .xlsx workbook, then it opens each workbook and breaks all links within that workbook.

VBA Code:
Option Explicit

Sub Break_Links_In_Workbooks_Within_Selected_Folder()

    Dim sourceFolder As String
    Dim currentFile As String
    Dim currentWorkbook As Workbook
 
    With Application.FileDialog(msoFileDialogFolderPicker)
        .ButtonName = "Select"
        .InitialFileName = Application.DefaultFilePath & "\"
        .Title = "Select Folder"
        If .Show = 0 Then Exit Sub
        sourceFolder = .SelectedItems(1) & "\"
    End With
 
    currentFile = Dir(sourceFolder & "*.xlsx") 'change the extension as desired
 
    If Len(currentFile) = 0 Then
        MsgBox "No workbooks found.", vbExclamation
        Exit Sub
    End If
 
    Application.ScreenUpdating = False
 
    Do
        Set currentWorkbook = Application.Workbooks.Open(sourceFolder & currentFile)
        BreakLinks currentWorkbook
        currentWorkbook.Close SaveChanges:=True
        currentFile = Dir
    Loop While Len(currentFile) > 0
 
    Application.ScreenUpdating = True

    MsgBox "Completed . . .", vbInformation
 
End Sub


Sub BreakLinks(ByVal wb As Workbook)
 
    Dim links As Variant
    Dim link As Variant
 
    links = wb.LinkSources(Type:=xlLinkTypeExcelLinks)
 
    If Not IsEmpty(links) Then
        For Each link In links
            wb.BreakLink _
                Name:=link, _
                Type:=xlLinkTypeExcelLinks
        Next link
    End If
 
End Sub

Hope this helps!
 
Upvote 0
The following code will prompt the user to select a folder, then it loops through each .xlsx workbook, then it opens each workbook and breaks all links within that workbook.

VBA Code:
Option Explicit

Sub Break_Links_In_Workbooks_Within_Selected_Folder()

    Dim sourceFolder As String
    Dim currentFile As String
    Dim currentWorkbook As Workbook
 
    With Application.FileDialog(msoFileDialogFolderPicker)
        .ButtonName = "Select"
        .InitialFileName = Application.DefaultFilePath & "\"
        .Title = "Select Folder"
        If .Show = 0 Then Exit Sub
        sourceFolder = .SelectedItems(1) & "\"
    End With
 
    currentFile = Dir(sourceFolder & "*.xlsx") 'change the extension as desired
 
    If Len(currentFile) = 0 Then
        MsgBox "No workbooks found.", vbExclamation
        Exit Sub
    End If
 
    Application.ScreenUpdating = False
 
    Do
        Set currentWorkbook = Application.Workbooks.Open(sourceFolder & currentFile)
        BreakLinks currentWorkbook
        currentWorkbook.Close SaveChanges:=True
        currentFile = Dir
    Loop While Len(currentFile) > 0
 
    Application.ScreenUpdating = True

    MsgBox "Completed . . .", vbInformation
 
End Sub


Sub BreakLinks(ByVal wb As Workbook)
 
    Dim links As Variant
    Dim link As Variant
 
    links = wb.LinkSources(Type:=xlLinkTypeExcelLinks)
 
    If Not IsEmpty(links) Then
        For Each link In links
            wb.BreakLink _
                Name:=link, _
                Type:=xlLinkTypeExcelLinks
        Next link
    End If
 
End Sub

Hope this helps!
Thanks for the help Domenic. Appreciated!
 
Upvote 0

Forum statistics

Threads
1,225,738
Messages
6,186,728
Members
453,368
Latest member
positivemind

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top