Форум программистов, компьютерный форум, киберфорум
C#: Web, ASP.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.55/11: Рейтинг темы: голосов - 11, средняя оценка - 4.55
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91

Покраска Excel при экспорте

14.08.2019, 07:46. Показов 2238. Ответов 28
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, нужно покрасить определенные столбцы в другой цвет, но проблема в том, что он красит не только столбцы, но и все ячейки до конца файла, как это исправить?

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
   var start = workSheet.Dimension.Start;
            var end = workSheet.Dimension.End;
            for (int col = start.Column; col <= end.Column; col++)
            {
 
                if (workSheet.Cells[1, col].Text == "STATUS51")
                {
                    workSheet.Column(col).Style.Fill.PatternType = ExcelFillStyle.Solid;
                    workSheet.Column(col).Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                }
                if (workSheet.Cells[1, col].Text == "LENGTH52")
                {
                    workSheet.Column(col).Style.Fill.PatternType = ExcelFillStyle.Solid;
                    workSheet.Column(col).Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                }
 
                if (workSheet.Cells[1, col].Text == "MTC")
                {
                    workSheet.Column(col).Style.Fill.PatternType = ExcelFillStyle.Solid;
                    workSheet.Column(col).Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
 
                }
 
            }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.08.2019, 07:46
Ответы с готовыми решениями:

Как выгрузить процесс Excel из памяти при экспорте данных из ASP.Net (C#) в Excel?
Здравствуйте! Как выгрузить процесс Excel из памяти при экспорте данных из ASP.Net (C#) в Excel? Вопрос обсуждается везде и много...

Ошибка при экспорте в Excel
Здравствуйте! При нажатии на кнопку Excel получаю ошибку: Control 'GridView1' of type 'GridView' must be placed inside a form tag with...

Проблемы при экспорте данных из GridView в Excel
мой вопрос такой.. я создал GridView и пытаюсь его экспортировать в Excel. работает нормально, но стоит мне в GridView добавить его...

28
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
16.08.2019, 11:10  [ТС]
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от V_Monomax Посмотреть сообщение
ок, тогда переделаем код метода:
C#
1
2
3
4
5
6
7
8
9
10
11
private void SetColumnLightGreen(int ColumnNumber)
        {
            ExcelPackage excel = new ExcelPackage();
            var workSheet = excel.Workbook.Worksheets.Add("Products");
            var end = workSheet.Cells.Where(c => c.Start.Column == ColumnNumber && !c.Value.ToString().Equals("")).Last();
            for (int i = 0; i < end; i++)
            {
                workSheet.Cells[i, ColumnNumber].Style.Fill.PatternType = ExcelFillStyle.Solid;
                workSheet.Cells[i, ColumnNumber].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
            }
        }
Ругается на строку
C#
1
 for (int i = 0; i < end; i++)
Оператор < не возможно применить к операнду типа "int" и "ExelRangeBase"
0
 Аватар для V_Monomax
1406 / 1260 / 20
Регистрация: 09.08.2011
Сообщений: 2,319
Записей в блоге: 1
16.08.2019, 14:22
Цитата Сообщение от 50SmRadosti Посмотреть сообщение
Ругается на строку
ок, тогда нам нужно из ExelRangeBase, вытащить номер ячейки.

Добавлено через 3 часа 5 минут
50SmRadosti, получайте, проверяйте:
C#
1
2
3
4
5
6
7
8
9
10
11
 private void SetColumnLightGreen(int ColumnNumber)
        {
            ExcelPackage excel = new ExcelPackage();
            var workSheet = excel.Workbook.Worksheets.Add("Products");
            var end = workSheet.Cells.Where(c => c.Start.Column == ColumnNumber && !c.Value.ToString().Equals("")).Last().End.Row;
            for (int i = 0; i < end; i++)
            {
                workSheet.Cells[i, ColumnNumber].Style.Fill.PatternType = ExcelFillStyle.Solid;
                workSheet.Cells[i, ColumnNumber].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
            }
        }
1
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
19.08.2019, 06:55  [ТС]
Цитата Сообщение от V_Monomax Посмотреть сообщение
ок, тогда нам нужно из ExelRangeBase, вытащить номер ячейки.

Добавлено через 3 часа 5 минут
50SmRadosti, получайте, проверяйте:
C#
1
2
3
4
5
6
7
8
9
10
11
 private void SetColumnLightGreen(int ColumnNumber)
        {
            ExcelPackage excel = new ExcelPackage();
            var workSheet = excel.Workbook.Worksheets.Add("Products");
            var end = workSheet.Cells.Where(c => c.Start.Column == ColumnNumber && !c.Value.ToString().Equals("")).Last().End.Row;
            for (int i = 0; i < end; i++)
            {
                workSheet.Cells[i, ColumnNumber].Style.Fill.PatternType = ExcelFillStyle.Solid;
                workSheet.Cells[i, ColumnNumber].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
            }
        }
Извиняюсь, что так долго не отвечал, проверил, на строке
C#
1
 var end = workSheet.Cells.Where(c => c.Start.Column == ColumnNumber && !c.Value.ToString().Equals("")).Last().End.Row;
выдает ошибку :
System.InvalidOperationException: "Последовательность не содержит элементов"
0
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
20.08.2019, 07:02  [ТС]
Додумался как сделать, можно закрывать, всем спасибо
0
 Аватар для V_Monomax
1406 / 1260 / 20
Регистрация: 09.08.2011
Сообщений: 2,319
Записей в блоге: 1
20.08.2019, 11:12
50SmRadosti, поделитесь получившимся решением, даже интересно, что там!
0
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
22.08.2019, 11:12  [ТС]
Цитата Сообщение от V_Monomax Посмотреть сообщение
50SmRadosti, поделитесь получившимся решением, даже интересно, что там!
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
 var start = workSheet.Dimension.Start;
            var end2 = workSheet.Dimension.End;
            var end = 1;
            while (workSheet.Cells[end, 1].Value != null)
            {
                end++;
            }
            for (int col = start.Column; col <= end2.Column; col++)
            {
 
                if (workSheet.Cells[1, col].Text == "STATUS51")
                {
                    for (var i = 1; i <= end - 1; i++)
                    {
                        workSheet.Cells[i, col].Style.Fill.PatternType = ExcelFillStyle.Solid;
                        workSheet.Cells[i, col].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                    }
 
                }
                if (workSheet.Cells[1, col].Text == "LENGTH52")
                {
                    for (var i = 1; i <= end - 1; i++)
                    {
                        workSheet.Cells[i, col].Style.Fill.PatternType = ExcelFillStyle.Solid;
                        workSheet.Cells[i, col].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                    }
                }
                if (workSheet.Cells[1, col].Text == "MTC")
                {
                    for (var i = 1; i <= end - 1; i++)
                    {
                        workSheet.Cells[i, col].Style.Fill.PatternType = ExcelFillStyle.Solid;
                        workSheet.Cells[i, col].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                    }
                }
            }
            for (var i = 1; i <= end - 1; i++)
            {
                    workSheet.Cells[i, 8].Style.Fill.PatternType = ExcelFillStyle.Solid;
                    workSheet.Cells[i, 8].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("Violet"));
            }
0
 Аватар для V_Monomax
1406 / 1260 / 20
Регистрация: 09.08.2011
Сообщений: 2,319
Записей в блоге: 1
22.08.2019, 12:33
50SmRadosti, а почему отказались от моих предложений:
C#
1
2
3
4
5
6
7
8
9
private void SetColumnLightGreen(int ColumnNumber, int EndCell, WorkSheet workSheet)
{
   
                    for (var i = 1; i <= EndCell - 1; i++)
                    {
                        workSheet.Cells[i, ColumnNumber].Style.Fill.PatternType = ExcelFillStyle.Solid;
                        workSheet.Cells[i, ColumnNumber].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                    }        
}
ну и соответственно в основном методе:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
            var start = workSheet.Dimension.Start;
            var end2 = workSheet.Dimension.End;
            var end = 1;
            while (workSheet.Cells[end, 1].Value != null)
            {
                end++;
            }
            for (int col = start.Column; col <= end2.Column; col++)
            {
                 if(workSheet.Cells[1, col].Text == "STATUS51"||
                    workSheet.Cells[1, col].Text == "LENGTH52"||
                    workSheet.Cells[1, col].Text == "MTC")
                   {
                       SetColumnLightGreen(col,end,workSheet);
                   }
                 
            }
            SetColumnLightGreen(8,end,workSheet);
Так ведь компактнее, и удобнее править.
0
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
23.08.2019, 05:38  [ТС]
Цитата Сообщение от V_Monomax Посмотреть сообщение
50SmRadosti, а почему отказались от моих предложений:
C#
1
2
3
4
5
6
7
8
9
private void SetColumnLightGreen(int ColumnNumber, int EndCell, WorkSheet workSheet)
{
   
                    for (var i = 1; i <= EndCell - 1; i++)
                    {
                        workSheet.Cells[i, ColumnNumber].Style.Fill.PatternType = ExcelFillStyle.Solid;
                        workSheet.Cells[i, ColumnNumber].Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                    }        
}
ну и соответственно в основном методе:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
            var start = workSheet.Dimension.Start;
            var end2 = workSheet.Dimension.End;
            var end = 1;
            while (workSheet.Cells[end, 1].Value != null)
            {
                end++;
            }
            for (int col = start.Column; col <= end2.Column; col++)
            {
                 if(workSheet.Cells[1, col].Text == "STATUS51"||
                    workSheet.Cells[1, col].Text == "LENGTH52"||
                    workSheet.Cells[1, col].Text == "MTC")
                   {
                       SetColumnLightGreen(col,end,workSheet);
                   }
                 
            }
            SetColumnLightGreen(8,end,workSheet);
Так ведь компактнее, и удобнее править.
Ошибки ловлю
0
 Аватар для V_Monomax
1406 / 1260 / 20
Регистрация: 09.08.2011
Сообщений: 2,319
Записей в блоге: 1
23.08.2019, 09:40
Цитата Сообщение от 50SmRadosti Посмотреть сообщение
Ошибки ловлю
какие?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.08.2019, 09:40
Помогаю со студенческими работами здесь

Как покрасить столбы при экспорте в Excel
Добрый день, имеется код экспорта в Excel System.Data.DataTable dit = null; try { dit =...

Работа RenderControl при экспорте Table (asp control) to Excel
Здравствуйте. Не могу понять почему не отрабатывает RenderControl для таблицы. Заполняю таблицу Table1 и выполняю экспорт: ...

при экспорте .csv в .mdb при наличии пустых полей проблема.
Esli v posledney stroke fila .csv est pustie polya, comp zavisaet. Kakaya mozhet bit' prichina? code takoy: const ForReading = 1 ...

Изменение формата ячейки при экспорте в Calc
Всем доброго времени суток. Озадачился. Формирую грид, далее из этого грида выгружаю даные в openoffice calc. С числовым форматом все...

Кодировка при экспорте данных в СSV-файл
Здравствуйте! Передо мной стоит задача экспорта данных в формат CSV. Я пробовал делать это следующим образом: 1. посылал запрос к БД ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
29
Ответ Создать тему
Новые блоги и статьи
Модель здравосохранения 16. Слишком хорошие и здоровые сотрудники уходят, недовольные зарплатой
anaschu 23.05.2026
Отладка увольнений и настройка производительности Сегодня во второй половине дня разобрались с механикой увольнений и настроили коэффициент сложности заданий. Вот что было сделано. . . .
Как я стал коммунистом))) Модель сохранения здоровья сотрудников, запись блога номер 15
anaschu 23.05.2026
Внезапно хорошее здоровье сотрудников не нужно капиталистам?))
Модель здравоСохранения 15. Как мы чинили AnyLogic модель рабочего коллектива: сочленение диаграммы состояний болезней и поломок в ресурспул
anaschu 23.05.2026
Как мы чинили AnyLogic модель рабочего коллектива Сегодня разобрались с пятью багами, из-за которых модель либо падала с ошибкой, либо давала совершенно бессмысленные результаты. Каждый баг был. . .
Диалоги с ИИ
zorxor 23.05.2026
Насколько я понимаю - Вы - Искусственный Интеллект. Это так? Да, всё верно. Я — искусственный интеллект. Я представляю собой большую языковую модель, созданную для помощи в самых разных задачах. . . .
Модель здравосохранения 14. Собираем всю модель вместе.
anaschu 22.05.2026
Модель собрана. В будущих постах на видео я покажу, как она работает. В этом посте запускаем её, проверяем результаты и разбираем что можно с ней делать дальше. Перед запуском проверяем. . .
Модель здравоохранения 13. Добавление самой системы здравоохранения.
anaschu 22.05.2026
В предыдущем посте мы настроили болезни. Теперь добавим события, которые управляют здоровьем всего коллектива, а также настроим рабочий график и расчёт финансов. В Main создаём четыре события. . . .
Модель здравоохранения 12. добавление болезней через ресурпул, как аварии
anaschu 22.05.2026
Болезни — это ключевая часть нашей модели. Нам нужно, чтобы работник периодически уходил на больничный, его задание при этом зависало, а после выздоровления работа возобновлялась. Реализуем это двумя. . .
Модель здравоохранения 11. Создаём классы Задание и Работник
anaschu 22.05.2026
В AnyLogic каждая заявка и каждый ресурс — это объект определённого класса. Нам нужно создать два класса: Задание (заявка) и Работник (ресурс). Класс Задание В дереве проекта нажимаем правой. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru