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

Считать данные из Excel-документа и записать в xml-файл

01.06.2023, 12:08. Показов 619. Ответов 4

Студворк — интернет-сервис помощи студентам
Всем привет. Задача вот такая:

Считать данные из Excel-документа "ФайлСИсходнымиДанными.xls" и записать в xml-файл (по аналогии с файлом "ФайлРезультат.xml").

При заполнения тегов RootXml, SchemaVersion, Period, Source, Form руководствуйтесь xml-файлом.

Тег Column - содержит номера и названия столбцов из xls-файла, за исключением столбца 2(Код счета бюджетного учета) .

Тег Document содержит атрибут ПлСч11, который принимает значения столбца 2(Код счета бюджетного учета), но при добавлении вначало символа "1" и обнулении последних трёх символов.
Например, столбец 2 содержит значение "20111510", то значение ПлСч11 будет "120111000".

Тег Data содержит атрибут СТРОКА, который принимает значения по возрастанию, начиная с "001" в пределах тега Document.

Тег <Data СТРОКА="960"> всегда присутствует в теге Document. Содержит итоговые суммы числовых столбцов.

Скрин с таблицы и результата приложу
Миниатюры
Считать данные из Excel-документа и записать в xml-файл   Считать данные из Excel-документа и записать в xml-файл  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.06.2023, 12:08
Ответы с готовыми решениями:

Считать данные с листа Excel и записать в таблицу Access и в файл последовательного доступа
Помогите пожалуста в VBA вообще чайник полнй ноль Нужно написать программу а я не знаю как. Задание звучит так надо написать программу,...

Как считать данные из xml и записать в строку
Как считать данные из xml и записать в строку Есть xml &lt;Root atr=&quot;aaaa&quot;&gt;&lt;Node...

Записать в xml файл данные из другого xml файла по критерию
Есть список узлов с информацией, которую необходимо проверить по критерию. Если с добычей и проверкой информации все прошло успешно, то вот...

4
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3429 / 2748 / 575
Регистрация: 04.09.2018
Сообщений: 8,626
Записей в блоге: 3
01.06.2023, 16:11
radgon, хвастаешься или спросить что хотел?
1
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3429 / 2748 / 575
Регистрация: 04.09.2018
Сообщений: 8,626
Записей в блоге: 3
01.06.2023, 19:47
Пачка классов, при сериализации которых создается XML-документ требуемого вида, с тестовой программой:
Кликните здесь для просмотра всего текста

Документ на выходе:
XML
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
<?xml version="1.0" encoding="utf-8"?>
<RootXml>
  <SchemaVersion Number="2" />
  <Period Date="2014-02-06">
    <Source ClassCode="Какой-то код 01" Code="819">
      <Form Code="178" Name="Счета в кредитных организациях" Status="0">
        <Column Num="1" Name="Номер банковского (лицевого) счета" />
        <Column Num="2" Name="Остаток средств на начало года на счете" />
        <Column Num="3" Name="Средства в пути на начало года" />
        <Column Num="4" Name="Остаток средств на счете на конец года" />
        <Column Num="5" Name="Средства в пути на отчетную дату (в рублях)" />
        <Document ПлСч11="120111000">
          <Data СТРОКА="001">
            <Px Num="1" Value="Федеральные" />
            <Px Num="2" Value="4590.00" />
            <Px Num="3" Value="45.00" />
            <Px Num="4" Value="67.00" />
            <Px Num="5" Value="110.00" />
          </Data>
          <Data СТРОКА="002">
            <Px Num="1" Value="Областные" />
            <Px Num="2" Value="3.00" />
            <Px Num="3" Value="2.00" />
            <Px Num="4" Value="23.00" />
            <Px Num="5" Value="347.00" />
          </Data>
          <Data СТРОКА="960">
            <Px Num="2" Value="8063.00" />
            <Px Num="3" Value="51.00" />
            <Px Num="4" Value="177.00" />
            <Px Num="5" Value="456.00" />
          </Data>
        </Document>
        <Document ПлСч11="120112000">
          <Data СТРОКА="001">
            <Px Num="1" Value="Федеральные" />
            <Px Num="2" Value="4590.00" />
            <Px Num="3" Value="45.00" />
            <Px Num="4" Value="67.00" />
            <Px Num="5" Value="110.00" />
          </Data>
          <Data СТРОКА="002">
            <Px Num="1" Value="Областные" />
            <Px Num="2" Value="3.00" />
            <Px Num="3" Value="2.00" />
            <Px Num="4" Value="23.00" />
            <Px Num="5" Value="347.00" />
          </Data>
          <Data СТРОКА="960">
            <Px Num="2" Value="8063.00" />
            <Px Num="3" Value="51.00" />
            <Px Num="4" Value="177.00" />
            <Px Num="5" Value="456.00" />
          </Data>
        </Document>
      </Form>
    </Source>
  </Period>
</RootXml>
Осталось реализовать считывание Excel, распихать его данные по соотв. полям классов и сериализовать.
1
0 / 0 / 0
Регистрация: 20.05.2023
Сообщений: 7
06.06.2023, 12:31  [ТС]
Очень мало информации дает. про классы и тд я и сам знаю. Но главная проблема состоит в том, как сделать множество одинаковых узлов, запарсить excel.
А ваш вариант только показывает названия классов и результативный xml
0
Эксперт JavaЭксперт по электроникеЭксперт .NET
 Аватар для wizard41
3429 / 2748 / 575
Регистрация: 04.09.2018
Сообщений: 8,626
Записей в блоге: 3
06.06.2023, 13:12
Лучший ответ Сообщение было отмечено radgon как решение

Решение

Цитата Сообщение от radgon Посмотреть сообщение
как сделать множество одинаковых узлов
Список (List<>) объектов указанного типа внутри класса-контейнера. Например, внутри тега Data содержатся объекты Px, (на картинке не особо видно как на самом деле называется). Тогда имеем объект:
C#
1
2
3
4
5
6
7
8
    public class Px
    {
        [XmlAttribute(AttributeName = "Num")]
        public int Num { get; set; }
 
        [XmlAttribute(AttributeName = "Value")]
        public string Value { get; set; }
    }
и класс Data, где они находятся:
C#
1
2
3
4
5
6
7
8
    public class Data
    {
        [XmlAttribute(AttributeName = "СТРОКА")]
        public string String { get; set; }
 
        [XmlElement(ElementName = "Px")]
        public List<Px> _Px { get; set; }
    }
Вот так закидываем весь класс данными с потолка:
Кликните здесь для просмотра всего текста
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
Root root = new()
{
    _SchemaVersion = new SchemaVersion() { Number = 2 },
    _Period = new Period()
    {
        Date = "2014-02-06",
        _Source = new Source()
        {
            ClassCode = "Какой-то код 01", Code = 819,
            _Form = new Form()
            {
                Code = 178, Name = "Счета в кредитных организациях", Status = 0,
                _Columns = new()
                {
                    new Column() { Num = 1, Name = "Номер банковского (лицевого) счета" },
                    new Column() { Num = 2, Name = "Остаток средств на начало года на счете" },
                    new Column() { Num = 3, Name = "Средства в пути на начало года" },
                    new Column() { Num = 4, Name = "Остаток средств на счете на конец года" },
                    new Column() { Num = 5, Name = "Средства в пути на отчетную дату (в рублях)" },
                },
                _Document = new() 
                {  
                    new Document() 
                    { 
                        WTF = "120111000",
                        _Data = new()
                        {
                            new Data() 
                            { 
                                String = "001",
                                _Px = new()
                                {
                                    new Px() { Num = 1, Value = "Федеральные" },
                                    new Px() { Num = 2, Value = "4590.00" },
                                    new Px() { Num = 3, Value = "45.00" },
                                    new Px() { Num = 4, Value = "67.00" },
                                    new Px() { Num = 5, Value = "110.00" },
                                }
                            },
 
                            new Data()
                            {
                                String = "002",
                                _Px = new()
                                {
                                    new Px() { Num = 1, Value = "Областные" },
                                    new Px() { Num = 2, Value = "3.00" },
                                    new Px() { Num = 3, Value = "2.00" },
                                    new Px() { Num = 4, Value = "23.00" },
                                    new Px() { Num = 5, Value = "347.00" },
                                }
                            },
 
                            new Data()
                            {
                                String = "960",
                                _Px = new()
                                {
                                    new Px() { Num = 2, Value = "8063.00" },
                                    new Px() { Num = 3, Value = "51.00" },
                                    new Px() { Num = 4, Value = "177.00" },
                                    new Px() { Num = 5, Value = "456.00" },
                                }
                            },
                        }
                    },
 
                    new Document()
                    {
                        WTF = "120112000",
                        _Data = new()
                        {
                            new Data()
                            {
                                String = "001",
                                _Px = new()
                                {
                                    new Px() { Num = 1, Value = "Федеральные" },
                                    new Px() { Num = 2, Value = "4590.00" },
                                    new Px() { Num = 3, Value = "45.00" },
                                    new Px() { Num = 4, Value = "67.00" },
                                    new Px() { Num = 5, Value = "110.00" },
                                }
                            },
 
                            new Data()
                            {
                                String = "002",
                                _Px = new()
                                {
                                    new Px() { Num = 1, Value = "Областные" },
                                    new Px() { Num = 2, Value = "3.00" },
                                    new Px() { Num = 3, Value = "2.00" },
                                    new Px() { Num = 4, Value = "23.00" },
                                    new Px() { Num = 5, Value = "347.00" },
                                }
                            },
 
                            new Data()
                            {
                                String = "960",
                                _Px = new()
                                {
                                    new Px() { Num = 2, Value = "8063.00" },
                                    new Px() { Num = 3, Value = "51.00" },
                                    new Px() { Num = 4, Value = "177.00" },
                                    new Px() { Num = 5, Value = "456.00" },
                                }
                            },
                        }
                    },
                }
            }
        }
    }
};

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

Считать данные из ячейки excel, и записать её в combobox
Добрый вечер! Не могли бы вы помочь с записью в combobox, ич ячейки Excel. Желательно с объяснением. Был бы очень признателен.

Считать данные из ячейки excel, и записать её в combobox
Как считать данные из ячейки excel. Что бы после это её можно было выбрать в combobox? Пробовал найти, в нигде ничего толкового нет.

Как считать данные из Excel и записать их в массив float?
Помогите пожалуйста!!!Очень нужно! как считать данные из Excel и записать их в массив float на языке с++.

Как считать данные из Excel и записать их в массив double
Как считать данные из Excel и записать их в массив double на языке Visual с#.

Как создать файл xml, записать/считать информацию файла?
В интернете нашла только такой код Dim xmlDoc As DOMDocument Set xmlDoc = New DOMDocument StartString$ =...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Жизнь в неопределённости
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
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru