我构建了一个函数,用于传递我想要搜索的国家/地区字符串以及我想从搜索结果中获取的文章数。
但是当搜索从Sitecore内容项回来时,我不想在标题的开头显示带有星号(*)的项目领域。这是函数名称:
protected IEnumerable<Item> ShowHomePageNews(int numOfArticles, string stringofCountries)
{
List<Item> items = new List<Item>();
Sitecore.Search.Index indx = SearchManager.GetIndex("my_index_name");
using (IndexSearchContext searchContext = indx.CreateSearchContext())
{
CombinedQuery query = new CombinedQuery();
QueryBase catQuery = new FieldQuery("countries", stringofCountries); //FieldName, FieldValue.
SearchHits results = searchContext.Search(catQuery); //Searching the content items by fields.
SearchResultCollection result = results.FetchResults(0, numOfArticles);
foreach (SearchResult i in result)
{
Lucene.Net.Documents.Field url = i.Document.GetField("_url");
Sitecore.Data.ItemUri itemUri = new Sitecore.Data.ItemUri(url.StringValue());
Sitecore.Data.Items.Item item = Sitecore.Context.Database.GetItem(itemUri.ToDataUri());
items.Add(item);
}
}
return items;
}
我在我的PageLoad上调用了这个函数:
rptHomePageNews.DataSource = ShowHomePageNews(4,“USA”);
这是我的标记:
<asp:Panel ID="HomePageNews" runat="server">
<asp:Repeater ID="rptHomePageNews" runat="server">
<ItemTemplate>
<li>
<%--<sc:FieldRenderer ID="FieldRenderer1" FieldName="Date" runat="server" Item="<%# Container.DataItem as Sitecore.Data.Items.Item %>" />--%>
<a href="<%# Sitecore.Links.LinkManager.GetItemUrl(Container.DataItem as Sitecore.Data.Items.Item) %>">
<sc:FieldRenderer ID="FieldRenderer2" FieldName="Title" runat="server" Item="<%# Container.DataItem as Sitecore.Data.Items.Item %>" />
</a>
</li>
</ItemTemplate>
</asp:Repeater>
我应该在ShowHomePageNews函数中进行哪些更改?
答案 0 :(得分:1)
如果您乐意使用Linq,可以使用以下内容替换foreach循环:
var db = Sitecore.Context.Database;
items = result
.Where(r => !r.Title.StartsWith("*"))
.Select(r => db.GetItem(new Sitecore.Data.ItemUri(r.Url).ToDataUri()))
.ToList();
答案 1 :(得分:1)
这里的一种方法是使用LINQ查询进行后过滤,如下所示:
string myTitleField = "My Title Field";
List<Item> results = items.Where(x => x.Fields[myTitleField].Value.Contains("*") == false).ToList();
这样效率不高,因为在开始过滤之前需要加载所有项目。如果效率不是问题,那么这至少提供了一种简单的过滤方式。
然而,我的建议是在索引中添加一个字段,并使用可以过滤的值标记记录(例如“TitleContainsAsterisk”)。然后,您可以更改查询以过滤掉该字段中包含“true”或“1”的结果。
编辑(适用于高级数据库抓取工具) 添加动态字段的配置和代码示例。 注意我没有编译或运行它,我是伪代码我现有的代码:
<dynamicFields hint="raw:AddDynamicFields">
<dynamicField type="MyNameSpace.TitleContainsAsterisk,MyBinary"
name="TitleContainsAsterisk" storageType="YES" indexType="TOKENIZED" vectorType="NO" boost="1f" />
</dynamicFields>
/// <summary>
/// Field Configuration (for the indexer) to index the if there is an asterisk in the title
/// </summary>
public class TitleContainsAsterisk: BaseDynamicField {
public override string ResolveValue(Item item) {
string myTitleField = "My Title Field";
bool containsAsterisk = item.Fields[myTitleField].Value.Contains("*");
return containsAsterisk ? "1" : "0";
}
}