Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
321 / 289 / 104
Регистрация: 12.04.2011
Сообщений: 925

Поиск в excel файле чисел и изменение разделителя тысяч и десятичных

23.03.2021, 12:39. Показов 497. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день.
Подскажите как реализовать поиск и замену в exel файлах цифры типа:
10500,67 на 10,500.67
150,3 на 150.3
2,2 на 2.2
25555,256 на 25,555.256
Открыть файл и перечисление ячеек, проверка пустая ли ячейка и её форматирование...
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
  
          private static string FormatNumber(string text)
        {
            if (double.TryParse(text, out double number))
            {
                     return number.ToString("N", CultureInfo.CreateSpecificCulture("en-US"));
                   // Console.WriteLine(number);
            }
            return text;
        }  
 
 
 
            foreach (Excel.Worksheet sheet in exDocument.Worksheets)
                {
                    Excel.Range last = sheet.Cells.SpecialCells(Excel.XlCellType.xlCellTypeLastCell, Type.Missing);
                    Excel.Range range = sheet.get_Range("A1", last);
                    int lastUsedRow = last.Row;
                    int lastUsedColumn = last.Column;
                    for (int rowIndex = 1; rowIndex <= lastUsedColumn; rowIndex++)
                    {
                        
                        for (int columnIndex = 1; columnIndex <=lastUsedRow; columnIndex++)
                        {
                            if (range.Cells[columnIndex, rowIndex].value2 != null)
                            {
                                string myString = ((Excel.Range)sheet.Cells[columnIndex, rowIndex]).Value2.ToString();
                                range.Cells[columnIndex, rowIndex] = FormatNumber(myString);
                                Console.WriteLine(range.Cells[columnIndex, rowIndex]);
                                                       // object missingVal = System.Reflection.Missing.Value;
                                // Excel.Range match = range.Cells[columnIndex, rowIndex].Value2.ToString().Find("<[0-9]@,[0-9]@>", missingVal, Excel.XlFindLookIn.xlValues, Excel.XlLookAt.xlPart,
                                //     Excel.XlSearchOrder.xlByRows, Excel.XlSearchDirection.xlNext, false, missingVal, missingVal);
                                //strok.Find.text= "<[0-9]@,[0-9]@>";
                            }
                        }
                    }
                }
В консоли пишет
C#
1
2
3
4
5
6
7
8
9
System.__ComObject
System.__ComObject
System.__ComObject
System.__ComObject
System.__ComObject
System.__ComObject
System.__ComObject
System.__ComObject
System.__ComObject
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
23.03.2021, 12:39
Ответы с готовыми решениями:

Locale - не верное отображение символа - разделителя тысяч для чисел
Объясните в чём может быть проблема символ - разделитель тысячной части в русской и украинской локали в консоли выглядит вместо пробела...

Колонка из чисел, поиск чисел в другом файле и запись в новом файле
Доброго времени суток! Очень сложная задачка, которую я не могу реализовать. Есть файл 2.txt, и много файлов от text_1.xls до text_M.xls....

Поиск и изменение HEX в файле
Помогите пожалуйста решить проблему Есть бинарный файл. Размер около 100 Мбайт. Есть HEX значения которые нужно поменять на другие и...

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

Изменение вида отображения таблиц в созданном файле Excel
Всем добра. Мучаю вот таблицы. Вот тут такой творческий вопрос - рисую я таблицы необходимые и сохраняю собственно в эксель файле. ...

Поиск в текстовом файле и его изменение
Есть файл .тхт, примерно такой структуры: cost 200/комент weight 3.0/комент и ище много других параметров. нужно найти...

Поиск в файле Excel
Всем привет. Надо бы как то написать программку с интерфейсом типа 6-7 кнопок, одна строка для ввода текста. И должна она искать то что...

В файле записана непустая последовательность целых чисел (целое число – это последовательность десятичных цифр, возможно начинающаяся знаком + или -)
В файле записана непустая последовательность целых чисел (целое число – это последовательность десятичных цифр, возможно начинающаяся...

Записи. Поиск, удаление, изменение элементов в файле
Здравствуйте. Нужно было создать программу &quot;библиотечный каталог&quot;, содержащую в себе: УДК, автор, название, год издания, количество...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Переходник 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
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru