Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 1
Регистрация: 23.03.2011
Сообщений: 21

Выгрзука в Excel из DataGridView. Нарушен порядок столбцов

30.07.2014, 13:40. Показов 1359. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Выгружаю данные из БД на DataGridView. Затем из DataGridView делаю экспорт в Excel. На компьютерах с Win7 все замечательно работает.
Попался компьютер с WinXP. Проблемы начались с того, что в DataGridView столбцы загрузились не в том порядке. Соответственно, и в Excel та же беда.
Задал порядок отображения в DataGridView вот так:
C#
1
dataGridView1.Columns["Время"].DisplayIndex = 1;
Теперь в Гриде нужный порядок, но в Excel по прежнему выгружает неправильно.
Выгружаю так.
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
            Microsoft.Office.Interop.Excel.Application Exl = new Microsoft.Office.Interop.Excel.Application();
            Microsoft.Office.Interop.Excel.Workbook wb;
            Microsoft.Office.Interop.Excel.Range excelcells;
            Microsoft.Office.Interop.Excel.Worksheet excelworksheet;
            Microsoft.Office.Interop.Excel.Sheets excelsheets;
 
            XlReferenceStyle RefStyle = Exl.ReferenceStyle;
 
 
            String TemplatePath = System.Windows.Forms.Application.StartupPath + @"\Шаблон.xls";
            try
            {
                wb = Exl.Workbooks.Add(TemplatePath); // !!! 
            }
            catch (System.Exception ex)
            {
                throw new Exception("Не удалось загрузить шаблон для экспорта " + TemplatePath + "\n" + ex.Message);
            }
            Worksheet ws = wb.Worksheets.get_Item(1) as Worksheet;
 
            Exl.Visible = false;
           
            for (int i = 0; i < dataGridView1.Rows.Count; i++)
            {
 
 
                (ws.Cells[8 + s, 1] as Range).Value2 = dataGridView1.Rows[i].Cells[0].Value.ToString(); //фронт
                (ws.Cells[8 + s, 2] as Range).Value2 = dataGridView1.Rows[i].Cells[1].Value.ToString(); //время
 
// и т.д.
 
            }
 
            
            Exl.Visible = true;
Почему Excel не подхватывает правильный порядок столбцов? Назначения свойства DisplayIndex для этого не достаточно?
Спасибо.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.07.2014, 13:40
Ответы с готовыми решениями:

Порядок столбцов в DataGridView
Привет всем! Подскажите, пожалуйста, как программно изменить порядок столбцов в DataGridView? Спасибо!

Datagridview порядок отображение столбцов
Здравствуйте.Подскажите пожалуйста как поменять порядок столбцов в datagridview в котором отображается база данных?

Изменить порядок расположения столбцов DataGridView
Есть dataGridView, который заполняется из БД таким способом: NpgsqlDataAdapter da = new...

2
147 / 73 / 17
Регистрация: 31.05.2014
Сообщений: 215
30.07.2014, 14:37
JohnLee, вы просто поменяли порядок отображения, а требовалось поменять местами столбцы.
0
0 / 0 / 1
Регистрация: 23.03.2011
Сообщений: 21
30.07.2014, 15:20  [ТС]
Ясно.
А можно как-то поменять местами столбцы в уже заполненном гриде?
Или это нужно предусматривать на этапе заполнения грида?

И не понятно, почему на Win7 порядок нормальный, а на WinXP скачет как попало.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.07.2014, 15:20
Помогаю со студенческими работами здесь

Программно поменять порядок столбцов в dataGridView
Как программно поменять местами столбцы в datagridview? И как узнать порядок ихнего расположения?

Как изменить порядок столбцов в Excel?
есть лист Excel, можно ли сделать так чтобы при его открытии пользователь видел сразу после столбца В столбец К спасибо за ответы

Экспорт столбцов из Datagridview в Excel
У меня есть Datagridview, в которой 3 столбца, есть 3 checkBox'a по их выделению и нажатию кнопки должен происходить экспорт в Excel ...

Экспорт определенных столбцов из datagridview в Excel
Доброго времени суток! Есть код в программе. который экспортирует ВСЕ данные из datagridview в Excel Dim rowsTotal, colsTotal As...

Экспорт datagridview в excel без скрытых столбцов
Вот так делаю экспорт в Excel без скрытых столбцов. var ws = wb.Worksheets.Item as Worksheet; for (int i = 0; i...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью. Данные берутся из регистра сведений, по которому настроено. . .
Хочу заставить корпорации вкладываться в здоровье сотрудников: делаю мат модель здравосохранения
anaschu 22.03.2026
e7EYtONaj8Y Z4Tv2zpXVVo https:/ / github. com/ shumilovas/ med2. git
Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru