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

Как получить границы / рамки вокруг диапазона в Excel, используя EPPlus

13.08.2019, 09:23. Показов 10115. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Код ниже генерирует границы для всех ячеек в пределах диапазона [2, 2, 5, 11], но я хочу, чтобы все было в рамках, как это сделать? .

C#
1
2
3
4
5
  var FirstTableRange = wsMyWorkSheet.Cells[2, 2, 5, 11];
        FirstTableRange.Style.Border.Top.Style = ExcelBorderStyle.Thick;
        FirstTableRange.Style.Border.Left.Style = ExcelBorderStyle.Thick;
        FirstTableRange.Style.Border.Right.Style = ExcelBorderStyle.Thick;
        FirstTableRange.Style.Border.Bottom.Style = ExcelBorderStyle.Thick;
Добавлено через 1 час 6 минут
Сделал двумя циклами, на проблема в том, что он рисует дальше моей таблицы, можно как то это убрать?
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
    for (int i = start.Column; i <= end.Column; i++)
            {
                workSheet.Column(i).Style.Fill.PatternType = ExcelFillStyle.Solid;
                workSheet.Column(i).Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightcoral"));
                workSheet.Column(i).Style.Border.BorderAround(ExcelBorderStyle.Medium, System.Drawing.Color.Black);
            
 
                if (workSheet.Cells[1, i].Text == "MTC")
                {
                    workSheet.Column(i).Style.Fill.PatternType = ExcelFillStyle.Solid;
                    workSheet.Column(i).Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightgreen"));
                }
            }
            for (int j = start.Row; j <= end.Row; j++)
            {
                workSheet.Row(j).Style.Fill.PatternType = ExcelFillStyle.Solid;
 
                workSheet.Row(j).Style.Border.BorderAround(ExcelBorderStyle.Medium, System.Drawing.Color.Black);
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.08.2019, 09:23
Ответы с готовыми решениями:

Нарисовать внешние границы выделенного диапазона ячеек в EXCEL
Товарищи подскажите как выделить только внешние границы у выделенного диапазона ячеек в excel ? Данным способом рисуются границы у...

Как, используя библиотеку EPPlus, поставить разрыв страницы (начать новую страницу)
до этого использовал Imports System.Runtime.InteropServices и в коде использовалxlsSheet.HPageBreaks.Add(xls.Range(&quot;A12&quot;))чтобы...

Как получить номер столбца известной ячейки? (EPPlus)
Хочу задать вычисляемое значение столбца worksheet.Cells в строке 21, чтобы получилось нечто вроде доступного в VBA свойства Column,...

4
999 / 358 / 135
Регистрация: 27.10.2006
Сообщений: 764
13.08.2019, 11:07
Попробуйте так,

xlSht - это ваш workSheet

C#
1
2
3
4
5
 ExcelRange UsedRange = xlSht.Cells[xlSht.Dimension.Address];
   UsedRange.Style.Border.Top.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
   UsedRange.Style.Border.Bottom.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
   UsedRange.Style.Border.Right.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
   UsedRange.Style.Border.Left.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
0
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
13.08.2019, 11:55  [ТС]
Цитата Сообщение от Pavel55 Посмотреть сообщение
Попробуйте так,

xlSht - это ваш workSheet

C#
1
2
3
4
5
 ExcelRange UsedRange = xlSht.Cells[xlSht.Dimension.Address];
   UsedRange.Style.Border.Top.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
   UsedRange.Style.Border.Bottom.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
   UsedRange.Style.Border.Right.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
   UsedRange.Style.Border.Left.Style = OfficeOpenXml.Style.ExcelBorderStyle.Thin;
Спасибо, помогло, можете подсказать, мне нужно еще поля покрасить, все в красный, и последнее в зеленый, я сделал циклом

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
   var start = workSheet.Dimension.Start;
            var end = workSheet.Dimension.End;
 
            for (int col = start.Column; col <= end.Column; col++)
            {
                workSheet.Column(col).Style.Fill.PatternType = ExcelFillStyle.Solid;
                workSheet.Column(col).Style.Fill.BackgroundColor.SetColor(ColorTranslator.FromHtml("lightcoral"));
                workSheet.Column(col).Style.Border.BorderAround(ExcelBorderStyle.Medium, System.Drawing.Color.Black);
 
 
                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
999 / 358 / 135
Регистрация: 27.10.2006
Сообщений: 764
13.08.2019, 12:29
Возможно вот в этой строке
C#
1
var end = workSheet.Dimension.End;
неверно определяется номер последнего столбца.

Попробуйте циклом идти от значения end к 1 и проверять ячейку на пусто или не пусто и дойти до реальных значений на листе. То есть если end = 50, то цикл с 50 до 1 и проверка workSheet.Cells[1,col].Value != null (или workSheet.Cells[1,col].Value != "")

P.S. Если в обычном Interop (не в Epplus), то последний столбец я ищу так - то есть поиск по 1 строке первую непустую ячейку справа
C#
1
int iLastCol = xlSht.Cells[1, xlSht.Columns.Count].End[Excel.XlDirection.xlToLeft].Column;
0
1 / 1 / 0
Регистрация: 26.03.2016
Сообщений: 91
13.08.2019, 12:45  [ТС]
Цитата Сообщение от Pavel55 Посмотреть сообщение
Возможно вот в этой строке
C#
1
var end = workSheet.Dimension.End;
неверно определяется номер последнего столбца.

Попробуйте циклом идти от значения end к 1 и проверять ячейку на пусто или не пусто и дойти до реальных значений на листе. То есть если end = 50, то цикл с 50 до 1 и проверка workSheet.Cells[1,col].Value != null (или workSheet.Cells[1,col].Value != "")

P.S. Если в обычном Interop (не в Epplus), то последний столбец я ищу так - то есть поиск по 1 строке первую непустую ячейку справа
C#
1
int iLastCol = xlSht.Cells[1, xlSht.Columns.Count].End[Excel.XlDirection.xlToLeft].Column;
Проблема в том, что записей может быть сколько угодно, и я не знаю сколько именно. Думаю, что тоже в этой строке, пока не понимаю, что с ней сделать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.08.2019, 12:45
Помогаю со студенческими работами здесь

Как сделать рамки вокруг элементов на форме?
Возможно ли задать рамки вокруг TabControl и panel не рисуя их самостоятельно???

Как убрать рамки вокруг кликабельного рисунка?
html .... &lt;img src=&quot;locks.jpg&quot; alt=&quot;lock links&quot; width=&quot;510&quot; height=&quot;110&quot; usemap=&quot;#locks&quot;/&gt; &lt;map name=&quot;locks&quot;&gt; ...

Как избавиться от пунктирной рамки вокруг ярлыков и папок?
Прилагаю скрин. Читал различные варианты в интернете. но мне ничего не помогло.

Как убрать рамки вокруг рисунков документа Word
Добрый день. У меня в документе Word2003 на рисунках расставлены такие рамки: Подобная рамка - как бы это выразится - фиксирует...

Как убрать наружные границы вокруг таблицы в HTML
Здравствуйте! Я новичок в сфере HTML, сейчас передо мною стоит задание сверстать сайт с помощью таблиц (не каким либо другим способом, а...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru