草庐IT

Zend_Search_Lucene_Field

全部标签

c# - Lucene.Net 写/读同步

我可以在打开索引(使用IndexReader)时将新文档写入(使用IndexWriter)吗?还是必须在写作之前关闭阅读?当索引打开用于写入(使用IndexWriter)时,我可以在索引中读取/搜索文档(使用IndexReader)吗?还是我必须在阅读之前关闭写作?Lucene.Net线程是否安全?还是必须自己写? 最佳答案 您可以随时打开任意数量的阅读器/搜索器,但只能打开一个写入器。这是由目录特定的锁强制执行的,通常涉及名为“write.lock”的文件。读者打开快照,作者向索引添加更多数据。在您的作者提交(IndexWrite

c# - 格式化日期时间错误 "Templates can be used only with field access, property access, single-dimension array index.."

在MVCRazorView中,我试图将DateTime字段格式化为仅显示时间。使用下面的代码我收到错误“模板只能用于字段访问、属性访问、一维数组索引或单参数自定义索引器表达式。”@(Html.DisplayFor(m=>row.LastUpdatedDate.ToString("HH:mm:ss")))任何帮助请问是什么导致了这个错误以及如何解决它?感谢您的帮助。 最佳答案 我遇到了同样的问题,我已经解决了。如果您想将“LastUpdatedDate”转换为特定格式,那么您可以试试这个:@Html.TextBoxFor(m=>row

c# - 有没有关于 Lucene.NET 的书籍

关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。关闭7年前。Improvethisquestion我在亚马逊上搜索过,但在lucene.net上找不到一本书。你们有没有在lucene.net上找到一本不错的书?

c# - Lucene - 短语中的通配符

我目前正在尝试使用Lucene来搜索索引中填充的数据。我可以通过将其括在方括号中来匹配精确的短语(即“处理文档”),但无法通过执行任何类型的“处理文档*”让Lucene找到该短语。最明显的区别是末尾的通配符。我目前正在尝试使用Luke查看和搜索索引。(它在解析时去掉了短语末尾的星号)在数据周围添加引号似乎是罪魁祸首,因为搜索document*会起作用,但“document*”不起作用如有任何帮助,我们将不胜感激 最佳答案 Lucene2.9有ComplexPhraseQueryParser它可以处理短语中的通配符。

c# - ProtoBuf-Net 和 Compact Framework 出现 "Invalid field in source data: 0"错误

有人知道使用ProtoBuf-Net在紧凑框架和完整.Net框架之间进行序列化/反序列化时有任何问题吗?我有一个名为LogData的类,我正在compactframework3.5下序列化,传输到服务器(运行.Netframework4.0),然后反序列化。有时它有效,有时它会抛出上述错误,我还没有将其缩小到任何特定原因。我用不同的值做了很多测试,但似乎无法找到错误发生时的任何韵律或原因。我在下面包括我的类(class)(减去各种构造函数)。我已多次查看两侧的字节缓冲区,但尚未发现通过线路从一侧发送到另一侧的数据存在差异。[ProtoContract]publicclassLogDat

c# - 如何使用 Lucene.net 实现自定义过滤器?

下面的代码来自LuceneInAction一书(最初使用Java)。它用于构建“允许”文档列表(从用户权限的角度来看)以过滤搜索结果。问题是termsDocs.Read()方法不接受通过引用传递的'doc'和'freq'数组,因此在位数组中设置位时它们仍然为空。任何人都可以提供帮助,使用Lucene自定义过滤器(尤其是在.net中)的示例似乎很少见。谢谢。publicclassLuceneCustomFilter:Lucene.Net.Search.Filter{string[]_luceneIds;publicLuceneCustomFilter(string[]luceneIds)

c# - Lazy<T> 延迟加载错误 : A field initializer cannot reference the non-static field, 方法或属性

我第一次尝试使用延迟加载来初始化我的类中的进度对象。但是,我收到以下错误:Afieldinitializercannotreferencethenon-staticfield,method,orproperty.privateLazym_progress=newLazy(()=>{longtotalBytes=m_transferManager.TotalSize();returnnewProgress(totalBytes);});在.NET2.0中,我可以执行以下操作,但我更愿意使用更新的方法:privateProgressm_progress;privateProgressPro

c# - 避免在重建期间删除当前的 Lucene.NET 索引

我是Lucene.NET的新手,但我正在使用anopensourcetool专为SitecoreCMS打造它使用Lucene.NET从CMS中索引大量内容。我昨天确认,当我重建索引时,当前的索引文件会被清除干净,因此依赖索引的任何东西在大约30-60秒(完整索引重建的时间)内都没有数据。是否有最佳实践或方法让Lucene.NET在新索引完全重建之前不覆盖当前索引文件?我基本上认为我希望它写入新的临时索引文件,并且在重建完成后让这些文件覆盖当前索引。我正在谈论的例子:建立新索引(~30秒)索引有大约500个文档使用代码访问索引中的数据并在网站上显示重建索引(~30秒)现在读取数据索引的任

已解决elasticsearch.exceptions.RequestError: TransportError(400, ‘search_phase_execution_exception’, ‘[

已解决(python操作elasticsearch模块查询失败)elasticsearch.exceptions.RequestError:TransportError(400,‘search_phase_execution_exception’,‘[terms]querydoesnotsupport[ti]’)文章目录报错代码报错翻译报错原因解决方法千人全栈VIP答疑群联系博主帮忙解决报错报错代码粉丝群里面的一个小伙伴想用python操作elasticsearch模块查询数据(当时他心里瞬间凉了一大截,跑来找我求助,然后顺利帮助他解决了,顺便记录一下希望可以帮助到更多遇到这个bug不会解决的

c# - 如何使用 Lucene.Net 执行 'contains' 搜索而不是 'starts with'

我们使用Lucene.NET在客户网站上实现全文搜索。搜索本身已经可以工作,但我们现在想要进行修改。目前,所有术语都附加了一个*,这会导致Lucene执行我将其归类为StartsWith搜索的操作。在未来,我们希望有一个搜索执行类似于Contains而不是StartsWith的搜索。我们使用Lucene.Net2.9.2.2标准分析器默认查询解析器示例:(Title:Orch*)匹配:Orchestra但是:(Title:rch*)不匹配:Orchestra我们希望第一个和第二个都匹配Orchestra。基本上我想要与这个问题中的问题完全相反,我不确定为什么Lucene对这个人执行Co