0

我有一个带有数据集和 gridview 的 ASP 站点,我想显示 XML 数据。

网格视图不是自动生成的,而是设置为查找hotelid、名称、状态、城市和国家。

目前,我已经手动编写了 XML,但是我已经包含了此 XML 中需要的包装器标签和其他错误标签,但是每当包含它们时,就会显示一个错误,指出 gridview 无法找到“HOTEL_ID”属性。无需额外数据即可正常工作。

XML 示例:

<REQUEST><ACTION>HOTEL_LIST</ACTION><RESPONSE><RESULT>0</RESULT>
<HOTELS>
<HOTEL><HOTELID>hot01</HOTELID><NAME>hotel test 1</NAME><CITY>birmingham</CITY><COUNTRY>england</COUNTRY><STATUS>active</STATUS></HOTEL>
<HOTEL><HOTELID>hot02</HOTELID><NAME>hotelabctestabc2abc</NAME><CITY>barca</CITY><COUNTRY>spain</COUNTRY><STATUS>inactive</STATUS></HOTEL>
<HOTEL><HOTELID>hot03</HOTELID><NAME>hotelabctestabcire</NAME><CITY>dublin</CITY><COUNTRY>ireland</COUNTRY><STATUS>active</STATUS></HOTEL>    
</HOTELS>
<ERRORS><ERROR><CODE></CODE><MESSAGE></MESSAGE></ERROR></ERRORS></RESPONSE></REQUEST>`

这是VB代码:

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles   Me.Load

    Dim teststring As String = "THE XML SHOWN ABOVE"

    Dim ds As New DataSet()
    Dim doc As New XmlDocument()

    doc.LoadXml(teststring)
    ds.ReadXml(New System.IO.StringReader(doc.OuterXml))

    GridView1.DataSource = ds
    GridView1.DataBind()


End Sub

`

如果我删除只留下唯一的酒店信息,它会起作用并找到该物业;

<HOTELS><HOTEL><HOTELID>hot01</HOTELID><NAME>hotel test 1</NAME><CITY>birmingham</CITY><COUNTRY>england</COUNTRY><STATUS>active</STATUS></HOTEL>

<HOTEL><HOTELID>hot02</HOTELID><NAME>hotelabctestabc2abc</NAME><CITY>barca</CITY><COUNTRY>spain</COUNTRY><STATUS>inactive</STATUS></HOTEL><HOTEL>

<HOTELID>hot03</HOTELID><NAME>hotelabctestabcire</NAME><CITY>dublin</CITY><COUNTRY>ireland</COUNTRY><STATUS>active</STATUS></HOTEL></HOTELS>

我究竟做错了什么?

谢谢。

4

1 回答 1

1

当您将这样的 XML 文档加载到 DataSet 中时,它会根据数据创建多个表。

为了仅将酒店信息绑定到您的 GridView,您需要确定数据集中的哪个表包含数据,然后将其绑定到 GridView

例如

GridView1.DataSource = ds.Tables(index_of_table_which_contains_data)

希望有帮助。

于 2012-09-14T09:14:41.363 回答