Выделение данных разными цветами в Excel с помощью C # в приложениях Windows - PullRequest
4 голосов
/ 10 марта 2010

Я работаю с приложением Windows. Мне нужно научиться выделять данные разными цветами и стилями в Excel. Я использую C # для экспорта данных в Excel.

Это код, который я использую для экспорта DataTable в Excel,

private void btnExportexcel_Click(object sender, EventArgs e)
{
    oxl = new Excel.Application();
    oxl.Visible = true;
    oxl.DisplayAlerts = false;

    wbook = oxl.Workbooks.Add(Missing.Value);

    wsheet = (Excel.Worksheet)wbook.ActiveSheet;
    wsheet.Name = "Customers";

    DataTable dt = clsobj.convert_datagrid_orderlist_to_datatable(dvgorderlist);

    int rowCount = 1;
    foreach (DataRow dr in dt.Rows)
    {
        rowCount += 1;
        for (int i = 1; i < dt.Columns.Count + 1; i++)
        {
            // Add the header the first time through
            if (rowCount == 2)
            {
                wsheet.Cells[1, i] = dt.Columns[i - 1].ColumnName;
            }
                wsheet.Cells[rowCount, i] = dr[i - 1].ToString();
            }
        }

        range = wsheet.get_Range(wsheet.Cells[1, 1],
        wsheet.Cells[rowCount, dt.Columns.Count]);
        range.EntireColumn.AutoFit();
    }

    wsheet = null;
    range = null;
}

1 Ответ

7 голосов
/ 10 марта 2010

Вам необходимо получить объект «Интерьер» ячейки или диапазона и установить для него цвет.

Range cellRange = (Range)wsheet.Cells[rowCount, i];
cellRange.Interior.Color = 255;

Цвета Excel представляют собой целочисленную последовательность, поэтому вы должны рассчитать значение для нужного цвета. Вам может пригодиться этот метод:

public static int ConvertColour(Color colour)
{
    int r = colour.R;
    int g = colour.G * 256;
    int b = colour.B * 65536;

    return r + g + b;
}

Тогда вы можете просто сделать это:

cellRange.Interior.Color = ConvertColour(Color.Green);

Вы можете установить стиль текста, используя свойство .font:

cellRange.Font.Size = "20";
cellRange.Font.Bold = true;

Существуют и другие свойства, такие как Color, Italic и Underline, которые можно использовать для получения нужного стиля.

...