views:

3723

answers:

2

Excel usually treats Conditional Formatting formulas as if they are array formulas, except when loading them from an Excel 2002/2003 XML Spreadsheet file.

This is only an issue with the Excel 2002/2003 XML Spreadsheet format... the native Excel format works fine, as does the newer Excel 2007 XML format (xlsx).

After loading the spreadsheet, it is possible to make it work correctly by selecting the formatted range, going to the Conditional Formatting dialog, and clicking OK--but this only fixes the problem for the session.

Test case:

Enter the following into a new sheet:

  A B C
1 N N N
2 x x x
3 x x x

Create this conditional format formula on cells A1:C1 (your choice of pretty colors for the format):

=(SUM(($A1:$C1="N")*($A$2:$C$2=A$3))>0)

This is an array formula that activates for A1, B1, and C1 whenever any of them has an "N" and the cell in row 2 below the "N" is equal to the cell in row 3 of the current column.

(This has been simplified from a real-world business spreadsheet. Sorry for the complexity of the test case, I am trying to find an easier test case to present here.)

And it works... you can alter the N's or the x's in any way you want and the formatting works just fine.

Save this as an XML Spreadsheet. Close Excel, and re-open the file. Formatting is now broken. Now, you can only activate conditional formatting if A1 is an "N" and A2 is the same as A3, B3, or C3. The values of B1, B2, C1, and C2 have no effect on the formatting.

Now, select A1:C1 and look at the conditional formatting formula. Exactly the same as before. Hit OK. Conditional formatting starts working again, and will work during the entire session the file is open.

Workarounds considered:

  1. Providing the file in native (BIFF) Excel format. Not an option, these spreadsheets are generated on the fly by a web server and this is only one of dozens of types of workbooks generated dynamically by our system.

  2. Providing the file in the Excel 2007 native XML format (xlsx). Not an option, current user base does not have Office 2007 or the compatibility plug-in.

  3. Asking users to select the range, enter the Conditional Formatting dialog, and hitting ok. Not an option in this case, unsophisticated users.

  4. Asking users to open the XML spreadsheet, save as native XLS, close, and re-open the XLS file. This does not work! Formatting remains broken in the native XLS format if it was loaded broken from an XML file. If (3) above is performed before saving, the XLS file will work properly.

I ended up rewriting the conditional formatting to not use array formulas. So I guess this is "answered" to some degree, but it's still an undocumented, if obscure, bug in Excel 2002/2003's handling of XML files.

+1  A: 

I tried to recreate the problem you describe. Here is what I found.

  • Could consistently recreate the problem using Excel 2003 on Windows XP when saving as an XML spreadsheet.

  • Could not reproduce the problem using Excel 2003 on Windows XP when saving as a standard xls spreadsheet.

  • Could not reproduce the problem using Excel 2007 on Windows Vista when saving the file in the native xlsx format.

  • Could not reproduce the problem using Excel 2007 on Windows Vista when saving the file in the Excel 97-2003 xls format.

    (Note: All instances of Excel and Windows are current with all Windows updates.)

I also added a simple conditional formatting formula to each test. In every case, it worked as expected after saving the file, closing Excel, and reopening the file.

So the answer seems to be to use the standard Excel 2003 file format when saving the file.

BTW, this is a very odd formatting formula. It is difficult to imagine how you would use it. It must be a very specific & unusual business case. I also have the feeling something is missing in your post. (I'm not accusing you of being dishonest – just wondering if you may have shortened the formula for readability.) If this is not the exact formula you are using, please edit your original post with the complete formula and I will be happy to revisit this issue.

TMarshall
A: 

You can find some tutorial videos for self studying the conditional formatting issue over the following pages: conditional formatting