Split excel file in multiple workbooks and save in multiple folders of same name











up vote
-1
down vote

favorite












To make the situation easily understandable I am taking example.



I have a excel files with following worksheets in it.
City1
City2
City3
City4
City5 and so on till 47 sheets



The file destination is "C:UsersDellDesktopCityData"



I want a VB code which could split file into individual sheets and place them in the folders of same names as the name of sheets (The folders do not exist and i want that code create the folders automatically) (The folders should be created as subfolders of the above destination folder)










share|improve this question


























    up vote
    -1
    down vote

    favorite












    To make the situation easily understandable I am taking example.



    I have a excel files with following worksheets in it.
    City1
    City2
    City3
    City4
    City5 and so on till 47 sheets



    The file destination is "C:UsersDellDesktopCityData"



    I want a VB code which could split file into individual sheets and place them in the folders of same names as the name of sheets (The folders do not exist and i want that code create the folders automatically) (The folders should be created as subfolders of the above destination folder)










    share|improve this question
























      up vote
      -1
      down vote

      favorite









      up vote
      -1
      down vote

      favorite











      To make the situation easily understandable I am taking example.



      I have a excel files with following worksheets in it.
      City1
      City2
      City3
      City4
      City5 and so on till 47 sheets



      The file destination is "C:UsersDellDesktopCityData"



      I want a VB code which could split file into individual sheets and place them in the folders of same names as the name of sheets (The folders do not exist and i want that code create the folders automatically) (The folders should be created as subfolders of the above destination folder)










      share|improve this question













      To make the situation easily understandable I am taking example.



      I have a excel files with following worksheets in it.
      City1
      City2
      City3
      City4
      City5 and so on till 47 sheets



      The file destination is "C:UsersDellDesktopCityData"



      I want a VB code which could split file into individual sheets and place them in the folders of same names as the name of sheets (The folders do not exist and i want that code create the folders automatically) (The folders should be created as subfolders of the above destination folder)







      excel-vba






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Nov 9 at 12:32









      Hashaam TDEA

      11




      11
























          2 Answers
          2






          active

          oldest

          votes

















          up vote
          1
          down vote













           Sub SplitSheets()
          Const FolName = "C:UsersDellDesktopCityData"
          Dim ws as worksheet
          for each ws in worksheets
          ws.copy
          Mkdir folname & ws.name
          activeworkbook.saveas folname & ws.name & "" & ws.name & ".xlsm",52
          activeworkbook.close
          next ws
          end sub





          share|improve this answer




























            up vote
            0
            down vote













            You can use this to split a workbook into separate sheets.



            Sub Splitbook()
            'Updateby20140612
            Dim xPath As String
            xPath = Application.ActiveWorkbook.Path
            Application.ScreenUpdating = False
            Application.DisplayAlerts = False
            For Each xWs In ThisWorkbook.Sheets
            xWs.Copy
            Application.ActiveWorkbook.SaveAs Filename:=xPath & "" & xWs.Name & ".xlsx"
            Application.ActiveWorkbook.Close False
            Next
            Application.DisplayAlerts = True
            Application.ScreenUpdating = True
            End Sub


            You can copy and move files using the code below.



            Sub Copy_Folder()
            'This example copy all files and subfolders from FromPath to ToPath.
            'Note: If ToPath already exist it will overwrite existing files in this folder
            'if ToPath not exist it will be made for you.
            Dim FSO As Object
            Dim FromPath As String
            Dim ToPath As String

            FromPath = "C:your_from_path" '<< Change
            ToPath = "C:your_to_path" '<< Change

            'If you want to create a backup of your folder every time you run this macro
            'you can create a unique folder with a Date/Time stamp.
            'ToPath = "C:your_to_path" & Format(Now, "yyyy-mm-dd h-mm-ss")

            If Right(FromPath, 1) = "" Then
            FromPath = Left(FromPath, Len(FromPath) - 1)
            End If

            If Right(ToPath, 1) = "" Then
            ToPath = Left(ToPath, Len(ToPath) - 1)
            End If

            Set FSO = CreateObject("scripting.filesystemobject")

            If FSO.FolderExists(FromPath) = False Then
            MsgBox FromPath & " doesn't exist"
            Exit Sub
            End If

            FSO.CopyFolder Source:=FromPath, Destination:=ToPath
            MsgBox "You can find the files and subfolders from " & FromPath & " in " & ToPath

            End Sub


            You could certainly make it more dynamic, if you want to sweep multiple files into multiple different folders. I think the best way to do that would be to list the folders in a column, and then loop through that list of items. Something like this would do the trick.



            Dim r As Range '-- if you don't declare it as a range type you get a variant type as default
            Dim c As Range '-- this is used to store the single cell in the For Each loop
            Set r = Range("A1:B10") '-- substitute your range as per your example
            For Each c In r '-- you could also use r.cells
            MsgBox c.Value '-- pass to your function instead of a call to the Message Box
            Next





            share|improve this answer





















              Your Answer






              StackExchange.ifUsing("editor", function () {
              StackExchange.using("externalEditor", function () {
              StackExchange.using("snippets", function () {
              StackExchange.snippets.init();
              });
              });
              }, "code-snippets");

              StackExchange.ready(function() {
              var channelOptions = {
              tags: "".split(" "),
              id: "1"
              };
              initTagRenderer("".split(" "), "".split(" "), channelOptions);

              StackExchange.using("externalEditor", function() {
              // Have to fire editor after snippets, if snippets enabled
              if (StackExchange.settings.snippets.snippetsEnabled) {
              StackExchange.using("snippets", function() {
              createEditor();
              });
              }
              else {
              createEditor();
              }
              });

              function createEditor() {
              StackExchange.prepareEditor({
              heartbeatType: 'answer',
              convertImagesToLinks: true,
              noModals: true,
              showLowRepImageUploadWarning: true,
              reputationToPostImages: 10,
              bindNavPrevention: true,
              postfix: "",
              imageUploader: {
              brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
              contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
              allowUrls: true
              },
              onDemand: true,
              discardSelector: ".discard-answer"
              ,immediatelyShowMarkdownHelp:true
              });


              }
              });














               

              draft saved


              draft discarded


















              StackExchange.ready(
              function () {
              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53225784%2fsplit-excel-file-in-multiple-workbooks-and-save-in-multiple-folders-of-same-name%23new-answer', 'question_page');
              }
              );

              Post as a guest















              Required, but never shown

























              2 Answers
              2






              active

              oldest

              votes








              2 Answers
              2






              active

              oldest

              votes









              active

              oldest

              votes






              active

              oldest

              votes








              up vote
              1
              down vote













               Sub SplitSheets()
              Const FolName = "C:UsersDellDesktopCityData"
              Dim ws as worksheet
              for each ws in worksheets
              ws.copy
              Mkdir folname & ws.name
              activeworkbook.saveas folname & ws.name & "" & ws.name & ".xlsm",52
              activeworkbook.close
              next ws
              end sub





              share|improve this answer

























                up vote
                1
                down vote













                 Sub SplitSheets()
                Const FolName = "C:UsersDellDesktopCityData"
                Dim ws as worksheet
                for each ws in worksheets
                ws.copy
                Mkdir folname & ws.name
                activeworkbook.saveas folname & ws.name & "" & ws.name & ".xlsm",52
                activeworkbook.close
                next ws
                end sub





                share|improve this answer























                  up vote
                  1
                  down vote










                  up vote
                  1
                  down vote









                   Sub SplitSheets()
                  Const FolName = "C:UsersDellDesktopCityData"
                  Dim ws as worksheet
                  for each ws in worksheets
                  ws.copy
                  Mkdir folname & ws.name
                  activeworkbook.saveas folname & ws.name & "" & ws.name & ".xlsm",52
                  activeworkbook.close
                  next ws
                  end sub





                  share|improve this answer












                   Sub SplitSheets()
                  Const FolName = "C:UsersDellDesktopCityData"
                  Dim ws as worksheet
                  for each ws in worksheets
                  ws.copy
                  Mkdir folname & ws.name
                  activeworkbook.saveas folname & ws.name & "" & ws.name & ".xlsm",52
                  activeworkbook.close
                  next ws
                  end sub






                  share|improve this answer












                  share|improve this answer



                  share|improve this answer










                  answered Nov 9 at 13:42









                  Harassed Dad

                  2,5661511




                  2,5661511
























                      up vote
                      0
                      down vote













                      You can use this to split a workbook into separate sheets.



                      Sub Splitbook()
                      'Updateby20140612
                      Dim xPath As String
                      xPath = Application.ActiveWorkbook.Path
                      Application.ScreenUpdating = False
                      Application.DisplayAlerts = False
                      For Each xWs In ThisWorkbook.Sheets
                      xWs.Copy
                      Application.ActiveWorkbook.SaveAs Filename:=xPath & "" & xWs.Name & ".xlsx"
                      Application.ActiveWorkbook.Close False
                      Next
                      Application.DisplayAlerts = True
                      Application.ScreenUpdating = True
                      End Sub


                      You can copy and move files using the code below.



                      Sub Copy_Folder()
                      'This example copy all files and subfolders from FromPath to ToPath.
                      'Note: If ToPath already exist it will overwrite existing files in this folder
                      'if ToPath not exist it will be made for you.
                      Dim FSO As Object
                      Dim FromPath As String
                      Dim ToPath As String

                      FromPath = "C:your_from_path" '<< Change
                      ToPath = "C:your_to_path" '<< Change

                      'If you want to create a backup of your folder every time you run this macro
                      'you can create a unique folder with a Date/Time stamp.
                      'ToPath = "C:your_to_path" & Format(Now, "yyyy-mm-dd h-mm-ss")

                      If Right(FromPath, 1) = "" Then
                      FromPath = Left(FromPath, Len(FromPath) - 1)
                      End If

                      If Right(ToPath, 1) = "" Then
                      ToPath = Left(ToPath, Len(ToPath) - 1)
                      End If

                      Set FSO = CreateObject("scripting.filesystemobject")

                      If FSO.FolderExists(FromPath) = False Then
                      MsgBox FromPath & " doesn't exist"
                      Exit Sub
                      End If

                      FSO.CopyFolder Source:=FromPath, Destination:=ToPath
                      MsgBox "You can find the files and subfolders from " & FromPath & " in " & ToPath

                      End Sub


                      You could certainly make it more dynamic, if you want to sweep multiple files into multiple different folders. I think the best way to do that would be to list the folders in a column, and then loop through that list of items. Something like this would do the trick.



                      Dim r As Range '-- if you don't declare it as a range type you get a variant type as default
                      Dim c As Range '-- this is used to store the single cell in the For Each loop
                      Set r = Range("A1:B10") '-- substitute your range as per your example
                      For Each c In r '-- you could also use r.cells
                      MsgBox c.Value '-- pass to your function instead of a call to the Message Box
                      Next





                      share|improve this answer

























                        up vote
                        0
                        down vote













                        You can use this to split a workbook into separate sheets.



                        Sub Splitbook()
                        'Updateby20140612
                        Dim xPath As String
                        xPath = Application.ActiveWorkbook.Path
                        Application.ScreenUpdating = False
                        Application.DisplayAlerts = False
                        For Each xWs In ThisWorkbook.Sheets
                        xWs.Copy
                        Application.ActiveWorkbook.SaveAs Filename:=xPath & "" & xWs.Name & ".xlsx"
                        Application.ActiveWorkbook.Close False
                        Next
                        Application.DisplayAlerts = True
                        Application.ScreenUpdating = True
                        End Sub


                        You can copy and move files using the code below.



                        Sub Copy_Folder()
                        'This example copy all files and subfolders from FromPath to ToPath.
                        'Note: If ToPath already exist it will overwrite existing files in this folder
                        'if ToPath not exist it will be made for you.
                        Dim FSO As Object
                        Dim FromPath As String
                        Dim ToPath As String

                        FromPath = "C:your_from_path" '<< Change
                        ToPath = "C:your_to_path" '<< Change

                        'If you want to create a backup of your folder every time you run this macro
                        'you can create a unique folder with a Date/Time stamp.
                        'ToPath = "C:your_to_path" & Format(Now, "yyyy-mm-dd h-mm-ss")

                        If Right(FromPath, 1) = "" Then
                        FromPath = Left(FromPath, Len(FromPath) - 1)
                        End If

                        If Right(ToPath, 1) = "" Then
                        ToPath = Left(ToPath, Len(ToPath) - 1)
                        End If

                        Set FSO = CreateObject("scripting.filesystemobject")

                        If FSO.FolderExists(FromPath) = False Then
                        MsgBox FromPath & " doesn't exist"
                        Exit Sub
                        End If

                        FSO.CopyFolder Source:=FromPath, Destination:=ToPath
                        MsgBox "You can find the files and subfolders from " & FromPath & " in " & ToPath

                        End Sub


                        You could certainly make it more dynamic, if you want to sweep multiple files into multiple different folders. I think the best way to do that would be to list the folders in a column, and then loop through that list of items. Something like this would do the trick.



                        Dim r As Range '-- if you don't declare it as a range type you get a variant type as default
                        Dim c As Range '-- this is used to store the single cell in the For Each loop
                        Set r = Range("A1:B10") '-- substitute your range as per your example
                        For Each c In r '-- you could also use r.cells
                        MsgBox c.Value '-- pass to your function instead of a call to the Message Box
                        Next





                        share|improve this answer























                          up vote
                          0
                          down vote










                          up vote
                          0
                          down vote









                          You can use this to split a workbook into separate sheets.



                          Sub Splitbook()
                          'Updateby20140612
                          Dim xPath As String
                          xPath = Application.ActiveWorkbook.Path
                          Application.ScreenUpdating = False
                          Application.DisplayAlerts = False
                          For Each xWs In ThisWorkbook.Sheets
                          xWs.Copy
                          Application.ActiveWorkbook.SaveAs Filename:=xPath & "" & xWs.Name & ".xlsx"
                          Application.ActiveWorkbook.Close False
                          Next
                          Application.DisplayAlerts = True
                          Application.ScreenUpdating = True
                          End Sub


                          You can copy and move files using the code below.



                          Sub Copy_Folder()
                          'This example copy all files and subfolders from FromPath to ToPath.
                          'Note: If ToPath already exist it will overwrite existing files in this folder
                          'if ToPath not exist it will be made for you.
                          Dim FSO As Object
                          Dim FromPath As String
                          Dim ToPath As String

                          FromPath = "C:your_from_path" '<< Change
                          ToPath = "C:your_to_path" '<< Change

                          'If you want to create a backup of your folder every time you run this macro
                          'you can create a unique folder with a Date/Time stamp.
                          'ToPath = "C:your_to_path" & Format(Now, "yyyy-mm-dd h-mm-ss")

                          If Right(FromPath, 1) = "" Then
                          FromPath = Left(FromPath, Len(FromPath) - 1)
                          End If

                          If Right(ToPath, 1) = "" Then
                          ToPath = Left(ToPath, Len(ToPath) - 1)
                          End If

                          Set FSO = CreateObject("scripting.filesystemobject")

                          If FSO.FolderExists(FromPath) = False Then
                          MsgBox FromPath & " doesn't exist"
                          Exit Sub
                          End If

                          FSO.CopyFolder Source:=FromPath, Destination:=ToPath
                          MsgBox "You can find the files and subfolders from " & FromPath & " in " & ToPath

                          End Sub


                          You could certainly make it more dynamic, if you want to sweep multiple files into multiple different folders. I think the best way to do that would be to list the folders in a column, and then loop through that list of items. Something like this would do the trick.



                          Dim r As Range '-- if you don't declare it as a range type you get a variant type as default
                          Dim c As Range '-- this is used to store the single cell in the For Each loop
                          Set r = Range("A1:B10") '-- substitute your range as per your example
                          For Each c In r '-- you could also use r.cells
                          MsgBox c.Value '-- pass to your function instead of a call to the Message Box
                          Next





                          share|improve this answer












                          You can use this to split a workbook into separate sheets.



                          Sub Splitbook()
                          'Updateby20140612
                          Dim xPath As String
                          xPath = Application.ActiveWorkbook.Path
                          Application.ScreenUpdating = False
                          Application.DisplayAlerts = False
                          For Each xWs In ThisWorkbook.Sheets
                          xWs.Copy
                          Application.ActiveWorkbook.SaveAs Filename:=xPath & "" & xWs.Name & ".xlsx"
                          Application.ActiveWorkbook.Close False
                          Next
                          Application.DisplayAlerts = True
                          Application.ScreenUpdating = True
                          End Sub


                          You can copy and move files using the code below.



                          Sub Copy_Folder()
                          'This example copy all files and subfolders from FromPath to ToPath.
                          'Note: If ToPath already exist it will overwrite existing files in this folder
                          'if ToPath not exist it will be made for you.
                          Dim FSO As Object
                          Dim FromPath As String
                          Dim ToPath As String

                          FromPath = "C:your_from_path" '<< Change
                          ToPath = "C:your_to_path" '<< Change

                          'If you want to create a backup of your folder every time you run this macro
                          'you can create a unique folder with a Date/Time stamp.
                          'ToPath = "C:your_to_path" & Format(Now, "yyyy-mm-dd h-mm-ss")

                          If Right(FromPath, 1) = "" Then
                          FromPath = Left(FromPath, Len(FromPath) - 1)
                          End If

                          If Right(ToPath, 1) = "" Then
                          ToPath = Left(ToPath, Len(ToPath) - 1)
                          End If

                          Set FSO = CreateObject("scripting.filesystemobject")

                          If FSO.FolderExists(FromPath) = False Then
                          MsgBox FromPath & " doesn't exist"
                          Exit Sub
                          End If

                          FSO.CopyFolder Source:=FromPath, Destination:=ToPath
                          MsgBox "You can find the files and subfolders from " & FromPath & " in " & ToPath

                          End Sub


                          You could certainly make it more dynamic, if you want to sweep multiple files into multiple different folders. I think the best way to do that would be to list the folders in a column, and then loop through that list of items. Something like this would do the trick.



                          Dim r As Range '-- if you don't declare it as a range type you get a variant type as default
                          Dim c As Range '-- this is used to store the single cell in the For Each loop
                          Set r = Range("A1:B10") '-- substitute your range as per your example
                          For Each c In r '-- you could also use r.cells
                          MsgBox c.Value '-- pass to your function instead of a call to the Message Box
                          Next






                          share|improve this answer












                          share|improve this answer



                          share|improve this answer










                          answered Nov 17 at 13:28









                          ryguy72

                          3,6931619




                          3,6931619






























                               

                              draft saved


                              draft discarded



















































                               


                              draft saved


                              draft discarded














                              StackExchange.ready(
                              function () {
                              StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53225784%2fsplit-excel-file-in-multiple-workbooks-and-save-in-multiple-folders-of-same-name%23new-answer', 'question_page');
                              }
                              );

                              Post as a guest















                              Required, but never shown





















































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown

































                              Required, but never shown














                              Required, but never shown












                              Required, but never shown







                              Required, but never shown







                              Popular posts from this blog

                              Guess what letter conforming each word

                              Run scheduled task as local user group (not BUILTIN)

                              Port of Spain