1

有没有办法,使用 C#.Net,基本上使用类似http://www.bing.com/images/search?q=microsoft&form=QBIL&qs=n&sk=&sc=8-4的东西,从中提取所有图像,并将其放入文件中?

4

2 回答 2

0

如果您想更清洁一点,那么使用 bing API 是最好的方法。在其 JSON/XML/SOAP 响应中,您将获得结果中每个图像的 url,您可以在循环中检索这些图像,或者在 LINQ 查询中更好地检索这些图像。

查看此PDF,它会告诉您入门的基本知识。

这是一个如何做到这一点的例子。首先获取允许您进行 API 查询的 APPID。

提出这样的要求

string url = "http://api.search.live.net/xml.aspx?Appid={0}&sources={1}&query={2}";
string completeUri = String.Format(url, AppId, "image", "microsoft");
HttpWebRequest webRequest = null;
webRequest = (HttpWebRequest)WebRequest.Create(completeUri);
HttpWebResponse webResponse = null;
webResponse = (HttpWebResponse)webRequest.GetResponse();
XmlReader xmlReader = null;
xmlReader = XmlReader.Create(webResponse.GetResponseStream());

然后创建一个将保留返回数据的类。

public class LiveSearchResultImage
{
    public string Title { get; set; }
    public string Description { get; set; }
    public string URI { get; set; }
    public string ImageURI { get; set; }
    public string ThumbnailURI { get; set; }
}

然后使用 LINQ 查询从响应中检索数据。

XDocument data = XDocument.Load(xmlReader);
IEnumerable<XNode> nodes = null;
nodes = data.Descendants(XName.Get("Results", IMAGE_NS)).Nodes();
if (nodes.Count() > 0)
{
    var results = from uris in nodes
    select new LiveSearchResultImage
    {
    URI =
    ((XElement)uris).Element(XName.Get("Url", IMAGE_NS)).Value,
    Title =
    ((XElement)uris).Element(XName.Get("Title", IMAGE_NS)).Value,
    ThumbnailURI =
    ((XElement)uris).Element(XName.Get("Thumbnail", IMAGE_NS)).Value,
    };
    return results;
}
于 2011-01-17T04:47:26.497 回答
0

您可以使用HTML Agility Pack及其HTMLWeb类来解析网页。

于 2011-01-17T02:16:18.237 回答