Getting cell-backgroundcolor in Excel with Open XML 2.0

后端 未结 1 347
醉话见心
醉话见心 2020-12-30 13:09

I am trying to get the backgroundcolor of a cell in a excel-spreadsheet. I am using Open XML 2.0 SDK and I am able to open the *.xlsx-file and to get cell-values for example

相关标签:
1条回答
  • 2020-12-30 13:30

    The fill pattern of a cell in an excel spreadsheet is composed of two colors: The background color and the foreground color. The term foreground color is a little bit misleading here. It is not the color of the font but the foreground color of the pattern fill.

    For example if you fill the background of a cell with a solid color the ForegroundColor property of the releated PatternFill object of the cell is set to the choosen solid color value where as The BackgroundColor object is set to the system foreground color. The PatternType property of the PatternFill object is set to PatternValues.Solid.

    So, to get the color value of your cell background (solid fill), you have to analyze the the ForegroundColor property of the releated PatternFill object. You have to determine the "type of color" the instance represents:

    1. An automatic color and system dependent color
    2. An indexed color.
    3. An ARGB color (alpha, red, green and blue)
    4. A theme based color.
    5. A tint value applied to the color.

    For more information about the different "color types" see the following link.

    Please note that the meaning of the InnerText property of the ForegroundColor and BackgroundColor class depends on the color type. For example in case of a theme based color the InnerText property is set to the index into the ColorScheme collection.

    The following example prints all background color information for all cells in a spreadsheet document:

    public static PatternFill GetCellPatternFill(Cell theCell, SpreadsheetDocument document)
    { 
      WorkbookStylesPart styles = SpreadsheetReader.GetWorkbookStyles(document);
    
      int cellStyleIndex;
      if (theCell.StyleIndex == null) // I think (from testing) if the StyleIndex is null
      {                               // then this means use cell style index 0.
        cellStyleIndex = 0;           // However I did not found it in the open xml 
      }                               // specification.
      else
      {
        cellStyleIndex = (int)theCell.StyleIndex.Value;
      }      
    
      CellFormat cellFormat = (CellFormat)styles.Stylesheet.CellFormats.ChildElements[cellStyleIndex];
    
      Fill fill = (Fill)styles.Stylesheet.Fills.ChildElements[(int)cellFormat.FillId.Value];
      return fill.PatternFill;  
    }
    
    private static void PrintColorType(SpreadsheetDocument sd, DocumentFormat.OpenXml.Spreadsheet.ColorType ct)
    {
      if (ct.Auto != null)
      {
        Console.Out.WriteLine("System auto color");
      }
    
      if (ct.Rgb != null)
      {
        Console.Out.WriteLine("RGB value -> {0}", ct.Rgb.Value);
      }
    
      if (ct.Indexed != null)
      {
        Console.Out.WriteLine("Indexed color -> {0}", ct.Indexed.Value);
    
        //IndexedColors ic = (IndexedColors)styles.Stylesheet.Colors.IndexedColors.ChildElements[(int)bgc.Indexed.Value];         
      }
    
      if (ct.Theme != null)
      {
        Console.Out.WriteLine("Theme -> {0}", ct.Theme.Value);
    
        Color2Type c2t = (Color2Type)sd.WorkbookPart.ThemePart.Theme.ThemeElements.ColorScheme.ChildElements[(int)ct.Theme.Value];
    
        Console.Out.WriteLine("RGB color model hex -> {0}", c2t.RgbColorModelHex.Val);
      }
    
      if (ct.Tint != null)
      {
        Console.Out.WriteLine("Tint value -> {0}", ct.Tint.Value);
      }
    }
    
    static void ReadAllBackgroundColors()
    {
      using (SpreadsheetDocument spreadsheetDocument = SpreadsheetDocument.Open("c:\\temp\\bgcolor.xlsx", false))
      {
        WorkbookPart workbookPart = spreadsheetDocument.WorkbookPart;
        foreach(WorksheetPart worksheetPart in workbookPart.WorksheetParts)
        {
          SheetData sheetData = worksheetPart.Worksheet.Elements<SheetData>().First();
    
          foreach (Row r in sheetData.Elements<Row>())
          {
            foreach (Cell c in r.Elements<Cell>())
            {            
              Console.Out.WriteLine("----------------");
              PatternFill pf = GetCellPatternFill(c, spreadsheetDocument);        
    
              Console.Out.WriteLine("Pattern fill type -> {0}", pf.PatternType.Value);
    
              if (pf.PatternType == PatternValues.None)
              {
                Console.Out.WriteLine("No fill color specified");
                continue;
              }
    
              Console.Out.WriteLine("Summary foreground color:");
              PrintColorType(spreadsheetDocument, pf.ForegroundColor);
              Console.Out.WriteLine("Summary background color:");
              PrintColorType(spreadsheetDocument, pf.BackgroundColor);                          
            }
          }     
        }
      }
    }
    
    static void Main(string[] args)
    { 
      ReadAllBackgroundColors();
    }
    
    0 讨论(0)
提交回复
热议问题