How do I make this Excel macro save in .xls (Excel 97-2003) format, instead of .xlsx?How to split spreadsheet into multiple spreadsheets with set number of rows?How do I create an Excel (.XLS and .XLSX) file in C# without installing Microsoft Office?How to avoid using Select in Excel VBAHow to change save type from excel workbook to excel 97-2003 in excel2010 using vba?VBA Excel macro message box auto closeSave Excel Workbook in different locationHow to reset sheet naming in ExcelExcel Macro: Lose line breaks pasting multiple (non-adjacent) rows into a different workbookVBA Macro lost after saving and closing as xslmcreating macro in excel

Did the Ottoman empire suppress the printing press?

Can I play a mimic PC?

Addressing unnecessary daily meetings with manager?

In Spider-Man: Far From Home, is this superhero name a reference to another comic book?

What happens when adult Billy Batson says "Shazam"?

When an electron changes its spin, or any other intrinsic property, is it still the same electron?

Is there a nice way to implement a conditional type with default fail case?

Why do you use the "park" gear to park a car and not only the handbrake?

Credit score and financing new car

Does a wizard need their hands free in order to cause their familiar from the Find Familiar spell to reappear?

What is /bin/red

How to tell someone I'd like to become friends without letting them think I'm romantically interested in them?

Why do we need common sense in AI?

Misrepresented my work history

How can I effectively communicate to recruiters that a phone call is not possible?

What's it called when the bad guy gets eaten?

LED glows slightly during soldering

Couldn't make condition-case work

Is there any reason why MCU changed the Snap to Blip

What is a "Lear Processor" and how did it work?

Can the spell Floating Disk cut objects?

Why does every calorie tracking app give a different target calorie count for the same goals?

Yet another hash table in C

Matrix with arrows and comments



How do I make this Excel macro save in .xls (Excel 97-2003) format, instead of .xlsx?


How to split spreadsheet into multiple spreadsheets with set number of rows?How do I create an Excel (.XLS and .XLSX) file in C# without installing Microsoft Office?How to avoid using Select in Excel VBAHow to change save type from excel workbook to excel 97-2003 in excel2010 using vba?VBA Excel macro message box auto closeSave Excel Workbook in different locationHow to reset sheet naming in ExcelExcel Macro: Lose line breaks pasting multiple (non-adjacent) rows into a different workbookVBA Macro lost after saving and closing as xslmcreating macro in excel






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








0















This macro is pretty close to exactly what I need:
How to split spreadsheet into multiple spreadsheets with set number of rows?



It splits a long Excel file into smaller files based on number of rows.



HOWEVER, I need to modify it to save the files as .xls (Excel 97-2003) format.



What do I need to change?



Here's what I'm working with right now:



Sub Test()
Dim wb As Workbook
Dim ThisSheet As Worksheet
Dim NumOfColumns As Integer
Dim RangeToCopy As Range
Dim RangeOfHeader As Range 'data (range) of header row
Dim WorkbookCounter As Integer
Dim RowsInFile 'how many rows (incl. header) in new files?

Application.ScreenUpdating = False

'Initialize data
Set ThisSheet = ThisWorkbook.ActiveSheet
NumOfColumns = ThisSheet.UsedRange.Columns.Count
WorkbookCounter = 1
RowsInFile = 100 'as your example, just 10 rows per file

'Copy the data of the first row (header)
Set RangeOfHeader = ThisSheet.Range(ThisSheet.Cells(1, 1), ThisSheet.Cells(1, NumOfColumns))

For p = 2 To ThisSheet.UsedRange.Rows.Count Step RowsInFile - 1
Set wb = Workbooks.Add

'Paste the header row in new file
RangeOfHeader.Copy wb.Sheets(1).Range("A1")

'Paste the chunk of rows for this file
Set RangeToCopy = ThisSheet.Range(ThisSheet.Cells(p, 1), ThisSheet.Cells(p + RowsInFile - 2, NumOfColumns))
RangeToCopy.Copy wb.Sheets(1).Range("A2")

'Save the new workbook, and close it
wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter
wb.Close

'Increment file counter
WorkbookCounter = WorkbookCounter + 1
Next p

Application.ScreenUpdating = True
Set wb = Nothing
End Sub









share|improve this question
























  • The Workbook.SaveAs and XlFileFormat enumeration documentation should give you what you need.

    – BigBen
    Mar 26 at 0:38












  • I see where I can get variable for FileFormat in both vaue and number format. I'm having trouble getting them inserted into the macro without breaking it.

    – JWgoldenb
    Mar 26 at 2:06











  • Actually, I think that worked. I just changed this: wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter to this: wb.SaveAs Filename:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, _ FileFormat:=xlExcel8 and that did the trick.

    – JWgoldenb
    Mar 26 at 2:17


















0















This macro is pretty close to exactly what I need:
How to split spreadsheet into multiple spreadsheets with set number of rows?



It splits a long Excel file into smaller files based on number of rows.



HOWEVER, I need to modify it to save the files as .xls (Excel 97-2003) format.



What do I need to change?



Here's what I'm working with right now:



Sub Test()
Dim wb As Workbook
Dim ThisSheet As Worksheet
Dim NumOfColumns As Integer
Dim RangeToCopy As Range
Dim RangeOfHeader As Range 'data (range) of header row
Dim WorkbookCounter As Integer
Dim RowsInFile 'how many rows (incl. header) in new files?

Application.ScreenUpdating = False

'Initialize data
Set ThisSheet = ThisWorkbook.ActiveSheet
NumOfColumns = ThisSheet.UsedRange.Columns.Count
WorkbookCounter = 1
RowsInFile = 100 'as your example, just 10 rows per file

'Copy the data of the first row (header)
Set RangeOfHeader = ThisSheet.Range(ThisSheet.Cells(1, 1), ThisSheet.Cells(1, NumOfColumns))

For p = 2 To ThisSheet.UsedRange.Rows.Count Step RowsInFile - 1
Set wb = Workbooks.Add

'Paste the header row in new file
RangeOfHeader.Copy wb.Sheets(1).Range("A1")

'Paste the chunk of rows for this file
Set RangeToCopy = ThisSheet.Range(ThisSheet.Cells(p, 1), ThisSheet.Cells(p + RowsInFile - 2, NumOfColumns))
RangeToCopy.Copy wb.Sheets(1).Range("A2")

'Save the new workbook, and close it
wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter
wb.Close

'Increment file counter
WorkbookCounter = WorkbookCounter + 1
Next p

Application.ScreenUpdating = True
Set wb = Nothing
End Sub









share|improve this question
























  • The Workbook.SaveAs and XlFileFormat enumeration documentation should give you what you need.

    – BigBen
    Mar 26 at 0:38












  • I see where I can get variable for FileFormat in both vaue and number format. I'm having trouble getting them inserted into the macro without breaking it.

    – JWgoldenb
    Mar 26 at 2:06











  • Actually, I think that worked. I just changed this: wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter to this: wb.SaveAs Filename:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, _ FileFormat:=xlExcel8 and that did the trick.

    – JWgoldenb
    Mar 26 at 2:17














0












0








0








This macro is pretty close to exactly what I need:
How to split spreadsheet into multiple spreadsheets with set number of rows?



It splits a long Excel file into smaller files based on number of rows.



HOWEVER, I need to modify it to save the files as .xls (Excel 97-2003) format.



What do I need to change?



Here's what I'm working with right now:



Sub Test()
Dim wb As Workbook
Dim ThisSheet As Worksheet
Dim NumOfColumns As Integer
Dim RangeToCopy As Range
Dim RangeOfHeader As Range 'data (range) of header row
Dim WorkbookCounter As Integer
Dim RowsInFile 'how many rows (incl. header) in new files?

Application.ScreenUpdating = False

'Initialize data
Set ThisSheet = ThisWorkbook.ActiveSheet
NumOfColumns = ThisSheet.UsedRange.Columns.Count
WorkbookCounter = 1
RowsInFile = 100 'as your example, just 10 rows per file

'Copy the data of the first row (header)
Set RangeOfHeader = ThisSheet.Range(ThisSheet.Cells(1, 1), ThisSheet.Cells(1, NumOfColumns))

For p = 2 To ThisSheet.UsedRange.Rows.Count Step RowsInFile - 1
Set wb = Workbooks.Add

'Paste the header row in new file
RangeOfHeader.Copy wb.Sheets(1).Range("A1")

'Paste the chunk of rows for this file
Set RangeToCopy = ThisSheet.Range(ThisSheet.Cells(p, 1), ThisSheet.Cells(p + RowsInFile - 2, NumOfColumns))
RangeToCopy.Copy wb.Sheets(1).Range("A2")

'Save the new workbook, and close it
wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter
wb.Close

'Increment file counter
WorkbookCounter = WorkbookCounter + 1
Next p

Application.ScreenUpdating = True
Set wb = Nothing
End Sub









share|improve this question
















This macro is pretty close to exactly what I need:
How to split spreadsheet into multiple spreadsheets with set number of rows?



It splits a long Excel file into smaller files based on number of rows.



HOWEVER, I need to modify it to save the files as .xls (Excel 97-2003) format.



What do I need to change?



Here's what I'm working with right now:



Sub Test()
Dim wb As Workbook
Dim ThisSheet As Worksheet
Dim NumOfColumns As Integer
Dim RangeToCopy As Range
Dim RangeOfHeader As Range 'data (range) of header row
Dim WorkbookCounter As Integer
Dim RowsInFile 'how many rows (incl. header) in new files?

Application.ScreenUpdating = False

'Initialize data
Set ThisSheet = ThisWorkbook.ActiveSheet
NumOfColumns = ThisSheet.UsedRange.Columns.Count
WorkbookCounter = 1
RowsInFile = 100 'as your example, just 10 rows per file

'Copy the data of the first row (header)
Set RangeOfHeader = ThisSheet.Range(ThisSheet.Cells(1, 1), ThisSheet.Cells(1, NumOfColumns))

For p = 2 To ThisSheet.UsedRange.Rows.Count Step RowsInFile - 1
Set wb = Workbooks.Add

'Paste the header row in new file
RangeOfHeader.Copy wb.Sheets(1).Range("A1")

'Paste the chunk of rows for this file
Set RangeToCopy = ThisSheet.Range(ThisSheet.Cells(p, 1), ThisSheet.Cells(p + RowsInFile - 2, NumOfColumns))
RangeToCopy.Copy wb.Sheets(1).Range("A2")

'Save the new workbook, and close it
wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter
wb.Close

'Increment file counter
WorkbookCounter = WorkbookCounter + 1
Next p

Application.ScreenUpdating = True
Set wb = Nothing
End Sub






excel vba






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Mar 26 at 0:36









BigBen

8,5693 gold badges8 silver badges21 bronze badges




8,5693 gold badges8 silver badges21 bronze badges










asked Mar 26 at 0:35









JWgoldenbJWgoldenb

1




1












  • The Workbook.SaveAs and XlFileFormat enumeration documentation should give you what you need.

    – BigBen
    Mar 26 at 0:38












  • I see where I can get variable for FileFormat in both vaue and number format. I'm having trouble getting them inserted into the macro without breaking it.

    – JWgoldenb
    Mar 26 at 2:06











  • Actually, I think that worked. I just changed this: wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter to this: wb.SaveAs Filename:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, _ FileFormat:=xlExcel8 and that did the trick.

    – JWgoldenb
    Mar 26 at 2:17


















  • The Workbook.SaveAs and XlFileFormat enumeration documentation should give you what you need.

    – BigBen
    Mar 26 at 0:38












  • I see where I can get variable for FileFormat in both vaue and number format. I'm having trouble getting them inserted into the macro without breaking it.

    – JWgoldenb
    Mar 26 at 2:06











  • Actually, I think that worked. I just changed this: wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter to this: wb.SaveAs Filename:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, _ FileFormat:=xlExcel8 and that did the trick.

    – JWgoldenb
    Mar 26 at 2:17

















The Workbook.SaveAs and XlFileFormat enumeration documentation should give you what you need.

– BigBen
Mar 26 at 0:38






The Workbook.SaveAs and XlFileFormat enumeration documentation should give you what you need.

– BigBen
Mar 26 at 0:38














I see where I can get variable for FileFormat in both vaue and number format. I'm having trouble getting them inserted into the macro without breaking it.

– JWgoldenb
Mar 26 at 2:06





I see where I can get variable for FileFormat in both vaue and number format. I'm having trouble getting them inserted into the macro without breaking it.

– JWgoldenb
Mar 26 at 2:06













Actually, I think that worked. I just changed this: wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter to this: wb.SaveAs Filename:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, _ FileFormat:=xlExcel8 and that did the trick.

– JWgoldenb
Mar 26 at 2:17






Actually, I think that worked. I just changed this: wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter to this: wb.SaveAs Filename:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, _ FileFormat:=xlExcel8 and that did the trick.

– JWgoldenb
Mar 26 at 2:17













1 Answer
1






active

oldest

votes


















0














The Workbook.SaveAs and xlFileFormat enumeration documentation are helpful here.



Change



wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter


to



wb.SaveAs FileName:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, FileFormat:=xlWorkbookNormal





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',
    autoActivateHeartbeat: false,
    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%2f55348277%2fhow-do-i-make-this-excel-macro-save-in-xls-excel-97-2003-format-instead-of%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    0














    The Workbook.SaveAs and xlFileFormat enumeration documentation are helpful here.



    Change



    wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter


    to



    wb.SaveAs FileName:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, FileFormat:=xlWorkbookNormal





    share|improve this answer



























      0














      The Workbook.SaveAs and xlFileFormat enumeration documentation are helpful here.



      Change



      wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter


      to



      wb.SaveAs FileName:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, FileFormat:=xlWorkbookNormal





      share|improve this answer

























        0












        0








        0







        The Workbook.SaveAs and xlFileFormat enumeration documentation are helpful here.



        Change



        wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter


        to



        wb.SaveAs FileName:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, FileFormat:=xlWorkbookNormal





        share|improve this answer













        The Workbook.SaveAs and xlFileFormat enumeration documentation are helpful here.



        Change



        wb.SaveAs ThisWorkbook.Path & "splitoutput" & WorkbookCounter


        to



        wb.SaveAs FileName:=ThisWorkbook.Path & "splitoutput" & WorkbookCounter, FileFormat:=xlWorkbookNormal






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Mar 26 at 2:11









        BigBenBigBen

        8,5693 gold badges8 silver badges21 bronze badges




        8,5693 gold badges8 silver badges21 bronze badges


















            Got a question that you can’t ask on public Stack Overflow? Learn more about sharing private information with Stack Overflow for Teams.







            Got a question that you can’t ask on public Stack Overflow? Learn more about sharing private information with Stack Overflow for Teams.



















            draft saved

            draft discarded
















































            Thanks for contributing an answer to Stack Overflow!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55348277%2fhow-do-i-make-this-excel-macro-save-in-xls-excel-97-2003-format-instead-of%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

            Kamusi Yaliyomo Aina za kamusi | Muundo wa kamusi | Faida za kamusi | Dhima ya picha katika kamusi | Marejeo | Tazama pia | Viungo vya nje | UrambazajiKuhusu kamusiGo-SwahiliWiki-KamusiKamusi ya Kiswahili na Kiingerezakuihariri na kuongeza habari

            SQL error code 1064 with creating Laravel foreign keysForeign key constraints: When to use ON UPDATE and ON DELETEDropping column with foreign key Laravel error: General error: 1025 Error on renameLaravel SQL Can't create tableLaravel Migration foreign key errorLaravel php artisan migrate:refresh giving a syntax errorSQLSTATE[42S01]: Base table or view already exists or Base table or view already exists: 1050 Tableerror in migrating laravel file to xampp serverSyntax error or access violation: 1064:syntax to use near 'unsigned not null, modelName varchar(191) not null, title varchar(191) not nLaravel cannot create new table field in mysqlLaravel 5.7:Last migration creates table but is not registered in the migration table

            은진 송씨 목차 역사 본관 분파 인물 조선 왕실과의 인척 관계 집성촌 항렬자 인구 같이 보기 각주 둘러보기 메뉴은진 송씨세종실록 149권, 지리지 충청도 공주목 은진현