пользовательские метки данных в диаграммах Excel с C# с использованием Microsoft Office Interop Excel - PullRequest
0 голосов
/ 03 августа 2020

Я создал диаграмму в Excel с помощью C# с помощью Microsoft Office Interop Excel, и мне не удается настроить метки данных

SeriesCollection seriesCollection7 = myChart7.Chart.SeriesCollection();
Series series7 = seriesCollection7.NewSeries();
series7.XValues = xValues7;
series7.Values = values7;
Excel.DataLabel dl1 = (Excel.DataLabel)series7.DataLabels(); // ERROR HERE
dl1.NumberFormat = "#0.0%";

Ответы [ 2 ]

0 голосов
/ 09 августа 2020

ВАРИАНТ 1 (спасибо @ Jack-J-Jun-MSFT)

        chartPage7.ApplyDataLabels(Excel.XlDataLabelsType.xlDataLabelsShowValue, false, true, false, false, false, true, true);
        series7.HasDataLabels = true;
        Excel.DataLabel dl1 = series7.DataLabels(0);
        dl1.NumberFormat = "#,0%";

ВАРИАНТ 2

        chartPage7.ApplyDataLabels(Excel.XlDataLabelsType.xlDataLabelsShowValue, false, true, false, false, false, true, true); // set label

        series7.DataLabels().NumberFormat = "#,0%";
0 голосов
/ 05 августа 2020

Вы можете попробовать следующий код для настройки меток данных.

        Excel.Application app = new Excel.Application();
        app.DisplayAlerts = false;
        object misValue = System.Reflection.Missing.Value;
        Excel.Workbook workbook = app.Workbooks.Open("D:\\3.XLSX");
        Excel.Worksheet worksheet = workbook.ActiveSheet;
        Excel.Range xlRange = worksheet.UsedRange;
        Excel.ChartObjects xlCharts = (Excel.ChartObjects)worksheet.ChartObjects(Type.Missing);
        Excel.ChartObject myChart = worksheet.ChartObjects(1);
        Excel.Chart chartPage = myChart.Chart;
        Excel.Series series1 = (Excel.Series)chartPage.SeriesCollection(1);
        series1.HasDataLabels = true;
        Excel.DataLabel dl1 = series1.DataLabels(1);
        dl1.Text = "Test1";
        workbook.Save();
        workbook.Close(true, misValue, misValue);

Я создаю столбчатую диаграмму и устанавливаю первую точку первой метки данных.

Примерно так:

введите описание изображения здесь

...