为Bing Search API添加分页功能到DataServiceQuery

时间:2012-06-15 18:57:13

标签: c# azure bing-api

我正在尝试添加Bing搜索(仅限Web结果)代理,以便我可以转到不同的结果页面。我知道我应该使用参数$ skip,但因为它有一个美元符号,我无法让它正确输出URL。

我只能错误地显示它(在&:

之后它需要美元符号

https://api.datamarket.azure.com/Data.ashx/Bing/SearchWeb/Web()?Query= '的Xbox' &安培;页= 2

...或者给我以下错误:

{将Linq表达式转换为URI时出错:无法添加查询选项'$ Page',因为它以保留字符'$'开头。}

这是我的代码(我的补充是在底部)。任何帮助将不胜感激。谢谢!

    public BingSearchContainer(Uri serviceRoot) : 
            base(serviceRoot) {
    }

    /// <summary>
    /// </summary>
    /// <param name="Query">Bing search query Sample Values : xbox</param>
    /// <param name="Market">Market. Note: Not all Sources support all markets. Sample Values : en-US</param>
    /// <param name="Adult">Adult setting is used for filtering sexually explicit content Sample Values : Moderate</param>
    /// <param name="Latitude">Latitude Sample Values : 47.603450</param>
    /// <param name="Longitude">Longitude Sample Values : -122.329696</param>
    /// <param name="WebFileType">File extensions to return Sample Values : XLS</param>
    public DataServiceQuery<WebResult> Web(String Query, String Market, String Adult, Double? Latitude, Double? Longitude, String WebFileType, String Page) {
        if ((Query == null)) {
            throw new System.ArgumentNullException("Query", "Query value cannot be null");
        }
        DataServiceQuery<WebResult> query;
        query = base.CreateQuery<WebResult>("Web");
        if ((Query != null)) {
            query = query.AddQueryOption("Query", string.Concat("\'", System.Uri.EscapeDataString(Query), "\'"));
        }
        if ((Market != null)) {
            query = query.AddQueryOption("Market", string.Concat("\'", System.Uri.EscapeDataString(Market), "\'"));
        }
        if ((Adult != null)) {
            query = query.AddQueryOption("Adult", string.Concat("\'", System.Uri.EscapeDataString(Adult), "\'"));
        }
        if (((Latitude != null) 
                    && (Latitude.HasValue == true))) {
            query = query.AddQueryOption("Latitude", Latitude.Value);
        }
        if (((Longitude != null) 
                    && (Longitude.HasValue == true))) {
            query = query.AddQueryOption("Longitude", Longitude.Value);
        }
        if ((WebFileType != null)) {
            query = query.AddQueryOption("WebFileType", string.Concat("\'", System.Uri.EscapeDataString(WebFileType), "\'"));
        }
        if ((Page != null))
        {
            query = query.AddQueryOption("Page", Page);
        }
        return query;
    }
}

2 个答案:

答案 0 :(得分:6)

解决方案相当简单。

  • 保持BingSearchContainer完整
  • 并添加分页并跳过 使用AddQueryOption函数的选项

使用以下代码来调用searchcontainer。

            var imageQuery = bingContainer.Image("XBOX" , null, null, null, null, null, null);
            imageQuery = imageQuery.AddQueryOption("$top", 20);
            imageQuery = imageQuery.AddQueryOption("$skip", 20);

答案 1 :(得分:0)

出于某种原因,markwilde的回答没有直接对我有用,但它让我知道如何解决类似的问题:使用最新版本的BingSearchContainer / API,选项 $ top $ skip 没有使用上面的技术添加,这让我感到惊讶,但我没有时间去调查,所以我使用了以下更残酷的技术。

在我的情况下,我将一些非null参数传递给 bingContainter.Image(...)方法,这些方法添加得很好但是当我尝试使用 AddQueryOption 添加 $ top $ skip 的方法,未添加这些选项。所以,我所做的只是修改 bingContainer.Image(...),将 $ top $ skip 值传递给它然后在该方法中添加它们:

public DataServiceQuery<ImageResult> Image(String Query, String Options, String Market, String Adult, Double? Latitude, Double? Longitude, String ImageFilters, int? top, int? skip ) {
        if ((Query == null)) {
            throw new System.ArgumentNullException("Query", "Query value cannot be null");
        }
        DataServiceQuery<ImageResult> query;
        query = base.CreateQuery<ImageResult>("Image");
        if ((Query != null)) {
            query = query.AddQueryOption("Query", string.Concat("\'", System.Uri.EscapeDataString(Query), "\'"));
        }
        if ((Options != null)) {
            query = query.AddQueryOption("Options", string.Concat("\'", System.Uri.EscapeDataString(Options), "\'"));
        }
        if ((Market != null)) {
            query = query.AddQueryOption("Market", string.Concat("\'", System.Uri.EscapeDataString(Market), "\'"));
        }
        if ((Adult != null)) {
            query = query.AddQueryOption("Adult", string.Concat("\'", System.Uri.EscapeDataString(Adult), "\'"));
        }
        if (((Latitude != null) 
                    && (Latitude.HasValue == true))) {
            query = query.AddQueryOption("Latitude", Latitude.Value);
        }
        if (((Longitude != null) 
                    && (Longitude.HasValue == true))) {
            query = query.AddQueryOption("Longitude", Longitude.Value);
        }
        if ((ImageFilters != null)) {
            query = query.AddQueryOption("ImageFilters", string.Concat("\'", System.Uri.EscapeDataString(ImageFilters), "\'"));
        }
        if (((top != null)
                    && (top.HasValue == true)))
        {
            query = query.AddQueryOption("$top", top.Value);
        }
        if (((skip != null)
                    && (skip.HasValue == true)))
        {
            query = query.AddQueryOption("$skip", skip.Value);
        }
        return query;
    }

由于Microsoft似乎经常更改此类,因此将来可能会或可能不会对您有所帮助。