私はいくつかのテーブルを持っています
<table>
<tr class="odd">
<td class="ind gray">1</td>
<td><b>acceding</b></td>
<td class="transcr">[əksˈiːdɪŋ]</td>
<td class="tran">присоединения</td>
</tr>
<!-- .... -->
<tr class="odd">
<td class="ind gray">999</td>
<td><b>related</b></td>
<td class="transcr">[rɪlˈeɪːtɪd]</td>
<td class="tran">родственный</td>
</tr>
</table>
1行で3つの「td」を解析したい。私のコード
Dictionary<string, Word> words = new Dictionary<string, Word>();
string text = webBrowser1.DocumentText;
HtmlAgilityPack.HtmlDocument doc = new HtmlAgilityPack.HtmlDocument();
doc.LoadHtml(text);
for (int i = 0; i < doc.DocumentNode.SelectNodes("//tr").Count; i++)
{
HtmlNode node = doc.DocumentNode.SelectNodes("//tr")[i];
Word word = null;
if (TryParseWord(node, out word))
{
try
{
if (!words.ContainsKey(word.eng))
{
words.Add(word.eng, word);
}
}
catch
{ continue; }
}
}
そして解析のための関数
private bool TryParseWord(HtmlNode node, out Word word)
{
word = null;
try
{
var eng = node.SelectNodes("//td")[1].InnerText;
var trans = node.SelectNodes("//td")[2].InnerText;
var rus = node.SelectNodes("//td")[3].InnerText;
word = new Word();
word.eng = eng;
word.rus = rus;
word.trans = trans;
return true;
}
catch
{
word = null;
return false;
}
}
私のメソッド TryParseWord では、最初の行からのみ値を取得します。この問題を解決するには?