С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/88: Рейтинг темы: голосов - 88, средняя оценка - 4.89
0 / 0 / 0
Регистрация: 09.02.2017
Сообщений: 22

Вывод данных на форму в виде таблицы

20.03.2017, 15:44. Показов 17299. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Уже третий день бьюсь и не могу решить задачу: программа считает некоторые значения (хранятся в массивах), далее эти значения нужно вывести в виде таблицы на форму и потом на печать. Сначала хотел выводить данные в textbox, но столкнулся с проблемой как нарисовать таблицу. Попробовал символы юникода для рамок, но получаются прерывистые линии. И вот теперь сижу и думаю как решить проблему, знающие люди помогите советом.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.03.2017, 15:44
Ответы с готовыми решениями:

Как сделать форму для отправки данных в виде таблицы?
У меня не получается сделать форму в виде таблицы (как в Excel), чтобы пользователь записал в неё всего много-много, а потом, нажав кнопку...

Вывод данных в виде таблицы
как оформить сделать по простому что бы выводили данными в виде таблицы вроде как можно использовать echo "<tr><td...

Вывод данных в виде таблицы
можно ли сделать одну целую таблицу,чтоб она выводила все i и соответствующие ей y y:=\sum_{i=1}^{n=10} e^i

4
 Аватар для Козадоев
163 / 153 / 33
Регистрация: 05.03.2013
Сообщений: 876
20.03.2017, 20:49
Есть такой элемент DataGridView. Он отображает таблицы. Достаточно ему указать объект в качестве источника данных. В простешем случае это может быть DataTable.
DataTable можно заполнить своими данными.
Этого достаточно чтобы выести таблицу с данными на экран в виде интерактивной формы.
Чтобы напечатать, в простейшем случае, при наличии установленного Word -достаточно создать шаблон и заполнить его через код приложения.
0
0 / 0 / 0
Регистрация: 09.02.2017
Сообщений: 22
21.03.2017, 20:43  [ТС]
Я не совсем точно выразился, вывод данных должен быть как в таблице, так и обычный текст. Например:
Выводится 3-4 строки текста, потом таблица с данными, потом еще текст и тд.
Я тут поэкспериментировал и выяснил что DataGridView можно вставить прямо в TextBox, соответственно сначала выводить текст, потом заполнить DataGridView потом снова текст и тд.
Я нашел несколько примеров как это работает и там DataGridView заполняют сразу, без DataTable. Возник вопрос насколько это правильно?
И еще сразу вопрос, а как организовать печать если нет Word на компьютере? Не хотелось бы привязываться к доп. по

Добавлено через 9 часов 20 минут
Собственно с выводом текста и таблицы в texbox я разобрался, остался вопрос как теперь вывести на печать... подскажите знающие люди
0
 Аватар для kesean
292 / 291 / 108
Регистрация: 04.09.2010
Сообщений: 638
21.03.2017, 22:18
Цитата Сообщение от Jekael Посмотреть сообщение
остался вопрос как теперь вывести на печать
ReportViewer?
1
0 / 0 / 0
Регистрация: 09.02.2017
Сообщений: 22
22.03.2017, 12:38  [ТС]
Нашел в интернете решение, правда не совсем элегантное, но работает)
Может кому нужно будет, выложу.
Это формирование print_page
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
private void printDocument1_PrintPage(object sender, System.Drawing.Printing.PrintPageEventArgs e)
        {
 
            
            Graphics g = e.Graphics;
            int x = 20;
            int y = 80;
            int cell_height = 0;
 
            int colCount = dataGridView1.ColumnCount;
            int rowCount = dataGridView1.RowCount;
 
            Font font = new Font("Tahoma", 9, FontStyle.Bold, GraphicsUnit.Point);
 
            int[] widthC = new int[colCount];
 
            int current_col = 0;
            int current_row = 0;
 
            while (current_col < colCount)
            {
                if (g.MeasureString(dataGridView1.Columns[current_col].HeaderText.ToString(), font).Width > widthC[current_col])
                {
                    widthC[current_col] = (int)g.MeasureString(dataGridView1.Columns[current_col].HeaderText.ToString(), font).Width;
                }
                current_col++;
            }
 
            while (current_row < rowCount)
            {
                while (current_col < colCount)
                {
                    if (g.MeasureString(dataGridView1[current_col, current_row].Value.ToString(), font).Width > widthC[current_col])
                    {
                        widthC[current_col] = (int)g.MeasureString(dataGridView1[current_col, current_row].Value.ToString(), font).Width;
                    }
                    current_col++;
                }
                current_col = 0;
                current_row++;
            }
 
            current_col = 0;
            current_row = 0;
 
            string value = "";
 
            int width = widthC[current_col];
            int height = dataGridView1[current_col, current_row].Size.Height;
 
            Rectangle cell_border;
            SolidBrush brush = new SolidBrush(Color.Black);
 
 
            while (current_col < colCount)
            {
                width = widthC[current_col];
                cell_height = dataGridView1[current_col, current_row].Size.Height;
                cell_border = new Rectangle(x, y, width, height);
                value = dataGridView1.Columns[current_col].HeaderText.ToString();
                g.DrawRectangle(new Pen(Color.Black), cell_border);
                g.DrawString(value, font, brush, x, y);
                x += widthC[current_col];
                current_col++;
            }
 
            current_col = 0;
            x = 20;
            y += cell_height;
 
            while (current_row < rowCount)
            {
                while (current_col < colCount)
                {                    
                    width = widthC[current_col];
                    cell_height = dataGridView1[current_col, current_row].Size.Height;
                    cell_border = new Rectangle(x, y, width, height);
                    value = dataGridView1[current_col, current_row].Value.ToString();
                    g.DrawRectangle(new Pen(Color.Black), cell_border);
                    g.DrawString(value, font, brush, x, y);
                    x += widthC[current_col];
                    current_col++;
                }
                current_col = 0;
                current_row++;
                x = 20;
                y += cell_height;
            }
        }
А это сама кнопка печати:
C#
1
2
3
4
5
PrintDocument Document = new PrintDocument();
            Document.PrintPage += new PrintPageEventHandler(printDocument1_PrintPage);
            PrintPreviewDialog dlg = new PrintPreviewDialog();
            dlg.Document = Document;
            dlg.ShowDialog();
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.03.2017, 12:38
Помогаю со студенческими работами здесь

Вывод данных в виде таблицы
Здравствуйте, помогите сделать шапку для фио студентов фио | номер зачётки | наименование группы | Оценки | ...

Вывод данных из БД в виде таблицы
Доброго времени суток! В общем имеется БД с фото. Нужно из нее вывести фото вряд по три штуки ну и вниз уже сколько будет получаться. ...

Вывод данных в виде таблицы
Всем привет! Подскажите новичку, как можно вывести введенные данные в виде таблицы? на данный момент информация выводится для каждого...

Вывод данных в виде таблицы
Есть таблица. Мне нужно написать эту таблицу, на языке паскаль так чтобы, автоматически происходило определение и подбор чисел из таблицы! ...

Вывод данных в виде таблицы
Подскажите пожалуйста как вывести элементы из таблицы sql (список юзеров) в виде таблицы??? я пытаюсь вывести так : &lt;ul&gt; ...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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 с разными данными.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru