Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.61/18: Рейтинг темы: голосов - 18, средняя оценка - 4.61
5 / 5 / 1
Регистрация: 02.05.2012
Сообщений: 53

Из html <table> в datagridview

05.08.2012, 17:26. Показов 3803. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет всем. 2 день думаю над тем как перенести значение из таблицы в html документе в datagridview. Страничка находится в интерне. Достаю ее вот так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
 public String getHtmlPage(String url, String login, String password)
        {
            try
            {
 
                WebRequest req = WebRequest.Create(url);
                req.Timeout = 10000;
                if (login != null && password != null)
                    req.Credentials = new NetworkCredential(login, password);
 
                WebResponse res = req.GetResponse();
                using (StreamReader reader = new StreamReader(res.GetResponseStream()))
                {
                    return reader.ReadToEnd();
                }
            }
            catch (Exception ex) { return ex.Message; } 
        }
Но как далее запихнуть данные из <table> не пойму. Структура страницы такова:
HTML5
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
<table border=1>
 
<tr>
<td>Name</td>
<td>Country</td>
<td>B-rate</td>
</tr>
 
<tr>
<td>Name</td>
<td>Country</td>
<td>Descr</td>
</tr>
 
<tr>
<td>Name</td>
<td>Country</td>
<td>Descr</td>
</tr>
 
<tr>
<td>Name</td>
<td>Country</td>
<td>Descr</td>
</tr>
 
 
</table>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.08.2012, 17:26
Ответы с готовыми решениями:

Вывод html table в datagridview
Доброго времени суток. Я парсю html table,но корректно вывести данные в datagridview не получается. Мне нужно в конечном итоге получить...

HTML Table View или как сделать HTML рекдактор
Я за советом. Я пытаюсь для простого HTML редактора сделать свой вид таблицы - с тем чтобы например отображались ее конторы когда...

Insert data into table(from select) using 2 DataGridView
Всем привет Ребята, помогите разобраться где у меня ошибка. 2 DataGridView, в первом DGV я храню Услуги во втором Cписок Заказов....

11
 Аватар для Петррр
6721 / 3570 / 900
Регистрация: 28.10.2010
Сообщений: 5,937
05.08.2012, 17:31
https://www.cyberforum.ru/post2070682.html
1
5 / 5 / 1
Регистрация: 02.05.2012
Сообщений: 53
05.08.2012, 17:53  [ТС]
Цитата Сообщение от Петррр Посмотреть сообщение
Спасибо) но это как-то сложновато для моих юных неокрепших мозгов.
Я делал через .Split и в масив, но как то уж очень полохо получилось.
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
  void baseload()
        {
             string[] tbody = new string[2];
            tbody[0] = "<table border=1>";
            tbody[1] = "</table>";
           
            string link = "http://mysite.com/base.html";
 
            String[] userful = getHtmlPage(link, null, null).Split(tbody, System.StringSplitOptions.RemoveEmptyEntries);
            string[] trs = new string[2];
            trs[0] = "<tr>";
            trs[1] = "</tr>";
            string[] tr = userful[1].Split(trs, System.StringSplitOptions.RemoveEmptyEntries);
 
            for (int i = 2; i < tr.Length; i ++)
            {
                string[] tds = new string[2];
                tds[0] = "<td>";
                tds[1] = "</td>";
 
                string[] td = tr[i].Split(tds, System.StringSplitOptions.RemoveEmptyEntries);
                dgv1.Rows.Add();
                int ind = 0;
                for (int k = 0; k < td.Length; k ++)
                {
                    dgv1.Rows[dgv1.Rows.Count - 1].Cells[ind].Value = td[k];
                    ind++;
                }
 
 
            }
 
        
        }
Нужно спарсить таблицу динамически. ее структура:


C#
1
2
3
4
5
6
7
8
9
<table border=1>
.......
<tr>
<td>Name</td>
<td>Country</td>
<td>B-rate</td>
</tr>
.......
</table>
0
556 / 510 / 25
Регистрация: 23.07.2009
Сообщений: 2,359
Записей в блоге: 1
05.08.2012, 17:57
HtmlAgilityPack
1
5 / 5 / 1
Регистрация: 02.05.2012
Сообщений: 53
05.08.2012, 18:21  [ТС]
HtmlAgilityPack - я тоже пробовал, не получилось)
после моего кода у меня просто пустой datagridview...

Добавлено через 5 минут
Вот, нашел ошибку, но теперь выводить только последнюю таблицу, а все до этого пустые
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
 void baseload()
        {
            string[] tbody = new string[2];
            tbody[0] = "<table border=1>";
            tbody[1] = "</table>";
           
            string link = "http://mysite.com/base.html";
 
            String[] userful = getHtmlPage(link, null, null).Split(tbody, System.StringSplitOptions.RemoveEmptyEntries);
            string[] trs = new string[2];
            trs[0] = "<tr>";
            trs[1] = "</tr>";
            string[] tr = userful[0].Split(trs, System.StringSplitOptions.RemoveEmptyEntries);
 
            for (int i = 3; i < tr.Length; i +=2)
            {
                string[] tds = new string[2];
                tds[0] = "<td>";
                tds[1] = "</td>";
 
                string[] td = tr[i].Split(tds, System.StringSplitOptions.RemoveEmptyEntries);
                dgv1.Rows.Add();
                int ind = 0;
                for (int k = 1; k < td.Length; k +=2)
                {
                    dgv1.Rows[dgv1.Rows.Count - 1].Cells[ind].Value = td[k];
                    ind++;
                }
 
 
            }
 
        
        }
0
Эксперт .NET
 Аватар для Casper-SC
4434 / 2094 / 404
Регистрация: 27.03.2010
Сообщений: 5,657
Записей в блоге: 1
05.08.2012, 19:07
Цитата Сообщение от Nikita_Serg Посмотреть сообщение
HtmlAgilityPack - я тоже пробовал, не получилось)
Ничего себе, да это самый толковый вариант. С Split ты далеко не уедешь. Поверь лучше HtmlAgilityPack использовать.

Добавлено через 4 минуты
Я писал программу по парсингу различных типов документов с таблицами. То есть разные виды документов (пусть 4 типа), в которых по несколько таблиц, да ещё и сделаны они как-то странно были. И парсить надо было сотни документов, бывало что html код отличался у одного и того же типа, то есть созданные в определённый промежуток времени документы отличались от более новых (незначительно, вообще по мелочи). Вот там HtmlAgilityPack мне реально помог и LINQ.

Добавлено через 22 минуты
А таблица всегда имеет такое кол-во элементов в списке или бывает и больше? Можешь ссылку дать на сайт и дай код своего DataGridView.
1
5 / 5 / 1
Регистрация: 02.05.2012
Сообщений: 53
05.08.2012, 19:10  [ТС]
Всегда такое к-во елементов. http://myneeds.site88.net/base.html. В датагридвиеве 3 столбца
0
 Аватар для Петррр
6721 / 3570 / 900
Регистрация: 28.10.2010
Сообщений: 5,937
05.08.2012, 19:22
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
using System.Data;
using System.Data.OleDb;
using System.IO;
using System.Net;
using System.Text;
using System.Windows.Forms;
 
namespace WindowsFormsApplication1
{
    public partial class Form1 : Form
    {
        DataTable table;
        public Form1()
        {
            InitializeComponent();
            table = new System.Data.DataTable();
            WebClient client = new WebClient();
            string html = client.DownloadString("http://myneeds.site88.net/base.html");
            File.WriteAllText("temp.html", html, Encoding.Default);
            OleDbConnection connection = new OleDbConnection(string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};"
                + "Extended Properties=\"HTML Import;HDR=YES;IMEX=1\";", "temp.html"));
            using (connection)
            {
                connection.Open();
                DataTable shemaTable = connection.GetOleDbSchemaTable(OleDbSchemaGuid.Tables,
                                                       new object[] { null, null, null, "TABLE" });
                string tableName = shemaTable.Rows[0]["TABLE_NAME"] as string;
                OleDbDataAdapter adapter = new OleDbDataAdapter(string.Format("SELECT * FROM [{0}]", tableName), connection);
                using (adapter)
                {
                    adapter.Fill(table);
                    dataGridView1.DataSource = table.DefaultView;
                }
            }
        }
    }
}
3
5 / 5 / 1
Регистрация: 02.05.2012
Сообщений: 53
05.08.2012, 19:28  [ТС]
Спасибо!
0
556 / 510 / 25
Регистрация: 23.07.2009
Сообщений: 2,359
Записей в блоге: 1
05.08.2012, 20:00
ну попробуй так (пример только, чтобы принцип продемонстрировать):

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
            System.Xml.XmlDocument doc = new System.Xml.XmlDocument();
            string str = "<table border=\"1\">\r\n";
            str += "<tr>\r\n";
            str += "<td>Name</td>\r\n";
            str += "<td>Country</td>\r\n";
            str += "<td>B-rate</td>\r\n";
            str += "</tr>\r\n";
            str += "<tr>\r\n";
            str += "<td>Name</td>\r\n";
            str += "<td>Country</td>\r\n";
            str += "<td>Descr</td>\r\n";
            str += "</tr>\r\n";
            str += "<tr>\r\n";
            str += "<td>Name</td>\r\n";
            str += "<td>Country</td>\r\n";
            str += "<td>Descr</td>\r\n";
            str += "</tr>\r\n";
            str += "<tr>\r\n";
            str += "<td>Name</td>\r\n";
            str += "<td>Country</td>\r\n";
            str += "<td>Descr</td>\r\n";
            str += "</tr>\r\n";
            str += "</table>";
            doc.LoadXml(str);
            System.Xml.XmlNodeList list = doc.SelectSingleNode ("table").SelectNodes("tr");
            int cnt = list.Count;
            foreach (System.Xml.XmlNode node in list){
                if (node != null) {
                    System.Xml.XmlNodeList list_td = node.SelectNodes("td");
                    string s = list_td[0].InnerText;
                    //...
                }
            }
это я не захотел на твой сайт заходить, т.к. там - ошибка. пришлось ручками набрать. а то XmlDocument имеет метод Load(string url)
1
5 / 5 / 1
Регистрация: 02.05.2012
Сообщений: 53
02.09.2012, 19:24  [ТС]
Петр, код просто идеален, но понадобилось маленькая модернизация программы и вышло так что чтение из файла не подойдет. Весь текст из файла загоняется в string (там с ним проводятся манипуляции ) и после это его уже надо подгрузить в датагридвиев. Помоги если не сложно, а то я очень много пока непонимаю.
0
 Аватар для Петррр
6721 / 3570 / 900
Регистрация: 28.10.2010
Сообщений: 5,937
02.09.2012, 20:06
В папку Temp запишите полученный string, и воспользуйтесь снова моим кодом.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.09.2012, 20:06
Помогаю со студенческими работами здесь

Cue -> html table
Никак не получается составить html таблицу из cue файла. :wall:%-) Надо, чтобы данные не повторялись, и таблица нормально и полностью,...

Экспорт HTML table в Excel
Здравствуйте. подскажите пожалуйста примером как можно экспортировать таблицу в эксель? Много чего перерыл не как не получается(

Html table row handling
Здравствуйте! Есть проект Java Spring WebFlow, в котором есть view .jsp с таблицей html. В таблицу из БД выгружаются объекты с...

Не добавляется строка в HTML table
Мне надо сделать чтобы по клику на кнопки 'Добавить' в моей HTML таблице (&lt;Table border=1&gt;) добавлялась пустая строка. Как это...

Table View на html как сделать
Подскажите как сделать что то наподобие uitableview (на ios) в html странице, может есть какие нить исходники. Просто использовать...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в 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 и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru