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

Ошибка с записью чисел в Excel

09.02.2019, 21:21. Показов 1958. Ответов 3

Студворк — интернет-сервис помощи студентам
Записываю некоторые числа в Excel, чтобы построить график. Записываю командой
C#
1
sheet.Cells[3 + iy, 1 + ix] = f(d2[i].Value).ToString();
Само значение f(d2[i].Value).ToString() считается и выводится на консоль правильно, но при отображении в Excel примерно все числа вида 3,18242345241543443 теряют запятую и становятся слишком большими (приложил скриншот). Если перед числом ставить ', то оно выводится нормально, но начинает распознаваться экселем как текст, поэтому с ним нельзя работать (если только не убрать вручную апострофы в куче ячеек).
Как исправить эту проблему???
И сразу интересно, есть ли какой-то шаблон команд, чтобы программно создать лист Excel, заполнить числами и по таблице построить график (3D график, как по функции z=f(x,y)), сделав всё командой в коде, а не вручную? И где можно почитать вообще об использовании Excel в .NET?
Миниатюры
Ошибка с записью чисел в Excel  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.02.2019, 21:21
Ответы с готовыми решениями:

Ошибка Excel в суммировании дробных чисел
"Ваш Excel не правильно считает!" - сколько раз слышал от экономистов/менеджеров подобные заявления... Потом разбирались с его расчётами...

Как сделать счётчик с записью каждого числа в Excel?
Добрый день. Очень нужно реализовать одну вещь, помогите плиз. В общем есть два числа 800 и 6000, нужно чтобы в экселе, в столбик...

Ошибка с записью в файл
Итак, мне в данной части кода не работает запись, т.е. когда я выбираю запись, то у меня сразу же завершается цикл записи и ничего не...

3
10 / 7 / 3
Регистрация: 25.02.2018
Сообщений: 86
10.02.2019, 13:49  [ТС]
Проблема не решается, даже если перед запись в Excel конвертировать числа в decimal или float. Причём у некоторых чисел запятая сдвигается на 1-2 разряда, а у некоторых вообще пропадает. На скриншоте показано, что реальные значения и они же после записи различаются
Миниатюры
Ошибка с записью чисел в Excel  
0
172 / 118 / 57
Регистрация: 08.01.2013
Сообщений: 664
10.02.2019, 19:53
Цитата Сообщение от Дмитрий Паскаль Посмотреть сообщение
есть ли какой-то шаблон команд, чтобы программно создать лист 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
36
37
38
39
40
class OpenOrCreateExcel
    {
        public Microsoft.Office.Interop.Excel.Application StatApp;
        public Microsoft.Office.Interop.Excel.Workbook StatWorkbook;
        public Microsoft.Office.Interop.Excel.Worksheet StatWorksheet;
        public string pf;
        public void OpenOrCreate()
        {
            StatApp = new Microsoft.Office.Interop.Excel.Application();
            if (File.Exists(pf))
            {
                StatWorkbook = StatApp.Workbooks.Open(pf);
                StatWorksheet = StatWorkbook.Worksheets[1];
            }
            else
            {
                StatWorkbook = StatApp.Workbooks.Add();
                StatWorksheet = StatWorkbook.Worksheets[1];
                StatWorksheet.Name = "Футбол";
                StatWorksheet = StatWorkbook.Worksheets.Add(
                    System.Reflection.Missing.Value,
                    StatWorkbook.Worksheets[StatWorkbook.Worksheets.Count],
                    System.Reflection.Missing.Value,
                    System.Reflection.Missing.Value);
                StatWorksheet.Name = "П(Футбол)";
                StatWorksheet = StatWorkbook.Worksheets[1];
                StatWorkbook.SaveAs(pf);
            }
        }
        public void CloseExcel()
        {
            StatWorkbook.Close(true);
            StatApp.Quit();
        }
        public void SaveExcel()
        {
            //exp.Save();
            StatWorkbook.Save();
        }
    }


Цитата Сообщение от Дмитрий Паскаль Посмотреть сообщение
Проблема не решается, даже если перед запись в Excel конвертировать числа в decimal или float
Мб нужно конвертировать в текст?
Кликните здесь для просмотра всего текста

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
public void WriteEventsExcel(string date, string time, string team1, string team2)
        {
            shozh = 0;
            ocex.StatWorksheet = ocex.StatWorkbook.Worksheets[1];
            int iLastRow = ocex.StatWorksheet.Cells[ocex.StatWorksheet.Rows.Count, "A"].End[Microsoft.Office.Interop.Excel.XlDirection.xlUp].Row;  //последняя заполненная строка в столбце А
            if (iLastRow == 1)
            {
                ocex.StatWorksheet.Cells[(iLastRow + 1), 1] = date;
                ocex.StatWorksheet.Cells[(iLastRow + 1), 2] = time;
                ocex.StatWorksheet.Cells[(iLastRow + 1), 3] = team1;
                ocex.StatWorksheet.Cells[(iLastRow + 1), 4] = team2;
                ocex.SaveExcel();
            }
            else
            {
                for (int i = 1; i <= iLastRow; i++)
                {
                    if (
                        (date.Equals(ocex.StatWorksheet.Cells[i, 1].Text)) &&
                        (time.Equals(ocex.StatWorksheet.Cells[i, 2].Text)) &&
                        (team1.Equals(ocex.StatWorksheet.Cells[i, 3].Text)) &&
                        (team2.Equals(ocex.StatWorksheet.Cells[i, 1].Text))
                      )
                    {
                        shozh = 1;
                    }
                }
                if (shozh == 0)
                {
                    ocex.StatWorksheet.Cells[(iLastRow + 1), 1] = date;
                    ocex.StatWorksheet.Cells[(iLastRow + 1), 2] = time;
                    ocex.StatWorksheet.Cells[(iLastRow + 1), 3] = team1;
                    ocex.StatWorksheet.Cells[(iLastRow + 1), 4] = team2;
                    ocex.SaveExcel();
                }
            }
        }
1
10 / 7 / 3
Регистрация: 25.02.2018
Сообщений: 86
10.02.2019, 20:45  [ТС]
Нет, нужно в ячейку записать именно число, потому что по этим числам потом график строится. А вообще я и так записывают string, но тогда у некоторых чисел запятая сдвигается или вообще исчезает

Добавлено через 15 минут
В общем, я убрал ToString() и стал записывать именно число, это помогло.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.02.2019, 20:45
Помогаю со студенческими работами здесь

Ошибка с записью WriteLn
var fl: TextFile; ... if not(AnswerQuestion=AnswerGroup.ItemIndex+1) then begin AssignFile(f, 'data.txt'); ...

Ошибка с записью в vector из файла
Доброго времени суток. Проблема с считыванием слов из текстового файла в функции read_file - считывает последнее слово файла дважды. ...

Ошибка с записью переменных в файл
Добрый день! Помогите, пожалуйста. В программе описаны две переменные public: // User declarations __fastcall...

Ошибка с записью объекта в ArrayList
Создал класс с конструктором public class Time_Table extends Activity { String depart, arrived, date; int cost, id; ...

Ошибка с записью в типизированный файл
В строчках под номером 21, 25, 29 при кампиляции кода, выдает ошибку о несовместимости типов. Если, окажется, что ошибку не исправить, то...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru