【发布时间】:2016-05-24 07:26:06
【问题描述】:
这是我目前所拥有的:
public void CreateObject()
{
const string ServerURl = "http://services.odata.org/northwind/northwind.svc/Customers";
DataSet ds = new DataSet();
DataTable sourcetable = new DataTable();
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(ServerURl);
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
richTextBox1.AppendText(response.StatusDescription);
Stream datastream = response.GetResponseStream();
StreamReader reader2 = new StreamReader(datastream);
using (StreamReader mySR = new StreamReader(datastream, Encoding.GetEncoding("iso-8859-1")))
{
XmlDocument lgnXml = new XmlDocument();
lgnXml.Load(mySR);
XmlNodeReader reader = new XmlNodeReader(lgnXml);
ds.ReadXml(reader);
foreach (DataTable table in ds.Tables)
{
foreach (DataRow dr in table.Rows)
{
sourcetable.Rows.Add(dr.ItemArray);
}
}
dataGridView1.DataSource = sourcetable;
}
}
private void button1_Click(object sender, EventArgs e)
{
CreateObject();
}
当我尝试运行它时,我得到了这个错误: 输入数组长于该表的列数
我猜我必须将列名添加到数据集或数据表中?我可以从 XML 中做到这一点吗?
编辑这是我使用 codeninja.sj 的方法运行它时的响应
+---+-------------------------------------------------------------+----------------------+
| | id | updated |
+---+-------------------------------------------------------------+----------------------+
| 1 | http://services.odata.org/northwind/northwind.svc/Customers | 2016-02-15T20:21:21Z |
+---+-------------------------------------------------------------+----------------------
【问题讨论】:
标签: c# xml winforms web-services api