Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 19.11.2014
Сообщений: 7

Некорректное отображение дат (OleDB, Excel, C#)

02.12.2014, 15:18. Показов 1108. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, коллеги.

Есть одна небольшая трудность, которая заключается в следующем: было написано приложение для сравнения двух экселевских файлов с выгрузкой через OleDB. Для того, чтобы все данные отображались в connection string был прописан аргумент "IMEX=1" (чтобы все данные выгружались, как текстовые), но появилась проблема с выгрузкой дат. При их выгрузке происходит перевод дат в текстовый формат и они уже выглядят не так "16.11.2014", а так "41308". После сравнения двух эксельников пишется лог с различающимися данными и дата туда, соответственно, выводится в виде числа (если ячейку вручную перевести в формат "Дата" в экселе, то отображается корректная дата). В связи с чем вопрос: Можно ли сделать как-нибудь так, чтобы дата отображалась корректно? Сразу скажу, что заранее неизвестно, что конкретно будет в ячейке сравнения (дата, число или текст).

Алгоритм работы программы:
- Берётся файл-эталон (экселевский) и выгружается при помощи OleDB в DataTable;
- Берётся файл с изменениями (экселевский) и тоже выгружается при помощи OleDB в DataTable;
- Два этих DataTable'a сравниваются;
- Различия в них пишутся в лог (экселевский);

Привожу код функции выгрузки файла в DataTable (exSheet - эксельник, filename - путь к эксельнику):

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
42
 DataTable DataFromExcelToDataTable(Excel.Worksheet exSheet, string filename, string sheetname = "")
        {
 
            string range = exSheet.UsedRange.Address.ToString().Replace("$", "");
            string sRequest = "SELECT * FROM [Лист1$" + range + "]";
            DataSet dsData = new DataSet();
 
            string sConnStr = String.Format("Provider=Microsoft.ACE.OLEDB.12.0;Data Source={0};Extended Properties=\"{1}\";", filename, "Excel 12.0;HDR=NO;IMEX=1;");
            using (OleDbConnection odcConnection = new OleDbConnection(sConnStr))
            {
                try
                {
                    odcConnection.Open();
                }
                catch (Exception e)
                {
                    Console.WriteLine("Файл " + filename + " не может быть импортирован, т.к. в настоящее время открыт под другим пользователем!\n" + e);
                    return null;
                }
 
                if (sRequest.IndexOf("Лист1$") != -1)
                {
                    using (DataTable dtMetadata = odcConnection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[4] { null, null, null, "TABLE" }))
                    {
                        for (int i = 0; i < dtMetadata.Rows.Count; i++)
                            if (dtMetadata.Rows[i]["TABLE_NAME"].ToString().IndexOf(sheetname + "$") == -1)
                                dtMetadata.Rows.Remove(dtMetadata.Rows[i]);
                        OleDbCommand odcCommand = new OleDbCommand(sRequest, odcConnection);
                        using (OleDbDataAdapter oddaAdapter = new OleDbDataAdapter(((OleDbCommand)odcCommand)))
                            oddaAdapter.Fill(dsData);
                    }
                }
                else
                {
                    OleDbCommand odcCommand = new OleDbCommand(sRequest, odcConnection);
                    using (OleDbDataAdapter oddaAdapter = new OleDbDataAdapter(odcCommand))
                        oddaAdapter.Fill(dsData);
                }
                odcConnection.Close();
            }
            return dsData.Tables[0];
        }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.12.2014, 15:18
Ответы с готовыми решениями:

Import-Csv и Excel - некорректное отображение кириллицы
Import-Csv Экспортирую файл exel.xlsx в формат *.csv, и не важно то ли это *.csv(ms-dos), или обычный *.csv, exel.xlsx ...

Некорректное отображение кириллицы при выгрузке в Excel
Кто сталкивался с проблемой с использованием библиотеки PHPExel. После выгрузки документа из PHP в exel не пишутся русские буква кодировки...

Данные из Excel через OleDB
Добрый вечер. Прошу помощи. Есть программа, которая перебирает файлы Excel и вытаскивает данные из них. Вот основная часть: ...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
02.12.2014, 15:18
Помогаю со студенческими работами здесь

OLEDB(excel) создание запроса с условием where
Никак не могу разобраться как нужно написать запрос... OleDbDataAdapter oCmd1 = new OleDbDataAdapter(&quot;SELECT * FROM &quot;,...

Считывание данных из Excel (OLEDB) в DataGridView
Приветствую всех! Может кто знает как разрешить задачу... Считываю данны из Excel, с листа Sheet1 из ячеек A1: D15 и отображаю с...

Пересечение интервалов дат в Excel. Вывод дат пересечения интервалов
Добрый день. Помогите пожалуйста. Мне надо найти совпадения в периодах работы одного и того же человека на разных предприятиях. Если он...

Некорректное отображение
Помогите, пожалуйста, с проблемой. Есть какой той каркас.Макет будет фиксированным. Я задаю контейнеру (там, где будет находиться весь...

Некорректное отображение в ИЕ
Добрый день! Как исправить некорректное отображение в ИЕ сайта advokatlogika.ru


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru