Solved

Export data from vb.net to Excel, error: Select method of Range class failed

Posted on 2008-09-30
2
888 Views
Last Modified: 2012-05-05
I'm currently making a vb.net program that will run several queries, and the results of each will automatically be put into worksheets in a new Excel workbook (i.e. one set of results will go into a new worksheet, the next set will go into a different worksheet, etc.).

I'm now trying to iterate though each of these worksheets and make formatting changes to them. The problem I'm having is related to Freezing Panes.  My original idea to perform the freeze was to manually select a cell in the row I want to freeze (i.e. Range("A8").select), and then use "Application.ActiveWindow.FreezePanes = true".  Whats interesting is that this does work, but only for the first worksheet in my workbook.  As soon as my program tries to select cell "A8" on any other sheet, it throws an error.

I've also tried doing this (oSheet is the current worksheet I'm iterating through):
"oSheet.Range("A8").Application.ActiveWindow.FreezePanes = true".

This doesn't throw an error (I'm not selecting a cell, technically), but it only freezes the panes on the first worksheet again. This is peculiar, because I am able to make other formatting changes (borders, fonts, change text in cells, page setups, etc.) to every other worksheet using my current method.


This is the code for applying the style changes to each worksheet (the applymacro function does all of the work). 
 
For counter = 0 To SheetTitles.Count - 1
    stdSheet = CType(xlSheets.Item(counter + 1), Excel.Worksheet)
    stdSheet.Name = SheetTitles((CountOfSheetsNeeded - 1) - counter)
    xlCells = stdSheet.Cells
    GenerateExcelFile(dsHolder((CountOfSheetsNeeded - 1) -counter).tables(0), xlCells) 'Fill in the data
    ApplyMacro(stdSheet)
 
Next
 
ApplyMacro header and line I'm getting an error on:
 
Private Sub ApplyMacro (ByVal oSheet as Excel.Worksheet)
   oSheet.Range("A8").Select()
End Sub

Open in new window

0
Comment
Question by:jacksonm1234
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
2 Comments
 
LVL 2

Author Comment

by:jacksonm1234
ID: 22616953
Any help? Anyone? Anyone?
0
 
LVL 2

Accepted Solution

by:
jacksonm1234 earned 0 total points
ID: 22623815
I figured it out. All I had to do was call the Activate() method on each sheet I was iterating through.

Thanks to everyone who helped...oh wait....
0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
VB.NET - Refactor Class per SOLID principles 2 33
Get sourcecode path 14 47
Add Combobox column to datagridview using vb.net 2 27
Copying from a network share 3 26
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
This article shows how to deploy dynamic backgrounds to computers depending on the aspect ratio of display
Email security requires an ever evolving service that stays up to date with counter-evolving threats. The Email Laundry perform Research and Development to ensure their email security service evolves faster than cyber criminals. We apply our Threat…
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

733 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question