开发者

Is it possible to return a list of all ranges from all worksheets in an Excel 2002 workbook?

开发者 https://www.devze.com 2022-12-26 23:56 出处:网络
I want to extract \"special\" data from an Excel 2002 (client requirement, cannot change) workbook and worksheets contained therein.I have classified r开发者_运维知识库anges in this \"special\" data c

I want to extract "special" data from an Excel 2002 (client requirement, cannot change) workbook and worksheets contained therein. I have classified r开发者_运维知识库anges in this "special" data category. I would like to acquire a list of all ranges in, ideally, all worksheets in a workbook. The attributes I'm interested in are the range name, and the range address. I have been googling for a while now, and have not found anything relevant.

I was assuming the Excel 2002 API would expose something like this:

ApplicationClass app = new ApplicationClass();
Workbook workbook = app.Workbooks.Open(@"c:\file.xls", ...);
Worksheet worksheet = workbook.Worksheets["sheet1"] as Worksheet;
Range[] ranges = worksheet.GetAllRanges();

or something similar. However, I am sadly mistaken.

Is this possible with Excel 2002?


If you are looking for all the ranges that are Named you should look at the Workbook.Names collection. Each Name in the Names collection has a RefersTo property that gives the Formula or Range Reference that is referenced by the Name. (But be aware that a Name can be a Formula rather than a Range Reference)
Dim oNM as Name

for each oNM in ActiveWorkbook.Names
debug.print oNM.Refersto
next oNM

0

精彩评论

暂无评论...
验证码 换一张
取 消