JAVA Lucene in Action教程完整版
- 格式:doc
- 大小:216.50 KB
- 文档页数:43
libreoffice uno java 实例-回复“LibreOffice UNO Java实例”是一个关于使用Java编程语言访问LibreOffice API的主题。
在本文中,我将会一步一步地回答这个主题,并提供一些具体的示例代码。
第一步:设置LibreOffice UNO开发环境在开始编写LibreOffice UNO Java实例之前,我们需要先设置好开发环境。
首先,你需要安装LibreOffice套件,确保将其完整安装到你的计算机中。
然后,你需要下载LibreOffice软件开发包(SDK),并将其安装到你的计算机中。
SDK包含了一些用于LibreOffice UNO开发的工具和资源。
第二步:创建一个Java项目在你的集成开发环境(IDE)中创建一个新的Java项目。
你可以选择使用任何你熟悉和喜欢的IDE,如Eclipse或IntelliJ IDEA。
第三步:导入LibreOffice UNO库为了能够访问LibreOffice的功能,我们需要导入LibreOffice UNO库。
这些库文件通常位于LibreOffice安装目录的"program"文件夹下。
在你的Java项目中,你需要把这些库文件添加到您的类路径中。
具体来说,你需要将以下JAR文件导入到你的项目中:- juh.jar- jurt.jar- ridl.jar- unoloader.jar- unoloader.jim可以通过在IDE中添加外部库或使用构建工具(如Maven或Gradle)来完成此操作。
第四步:连接到LibreOffice实例接下来,我们需要连接到一个LibreOffice实例。
在Java中,我们可以使用com.sun.starp.helper.Bootstrap类的静态方法创建一个连接。
该方法的一个参数是一个URL,用于指定要连接的LibreOffice实例的位置。
如果LibreOffice在默认安装目录中,URL可以设置为"socket,host=localhost,port=8100;urp;StarOffice.ServiceManager"。
C#编写了⼀个基于的搜索引擎查询通⽤⼯具类:SearchEngineUtil 最近由于⼯作原因,⼀直忙于公司的各种项⽬(⼤部份都是基于spring cloud的微服务项⽬),故有⼀段时间没有与⼤家分享总结最近的技术研究成果的,其实最近我⼀直在不断的深⼊研究学习Spring、Spring Boot、Spring Cloud的各种框架原理,同时也随时关注着.NET CORE的发展情况及最新技术点,也在极客时间上订阅相关的专栏,只要下班有空我都会去认真阅读观看,纸质书箱也买了⼀些,总之近⼀年都是在通过:微信技术公众号(.NET、JAVA、算法、前端等技术⽅向)、极客时间、技术书箱不断的吸取、借鉴他⼈之精华,从⽽不断的充实提⾼⾃⼰的技术⽔平,所谓:学如逆⽔⾏⾈,不进则退,⼯作中学习,学习后⼯作中运⽤,当然写⽂章分享是⼀种总结,同时也是“温故⽽知新”的最佳应⽤。
using .Analysis.PanGu;using .Documents;using .Index;using .QueryParsers;using .Search;using .Store;using NLog;using PanGu;using PanGu.HighLight;using System;using System.Collections.Generic;using System.IO;using System.Linq;using System.Reflection;using System.Text;namespace mon{/// <summary>/// Lucene 搜索引擎实⽤⼯具类/// Author:zuowenjun/// </summary>public class SearchEngineUtil{/// <summary>/// 创建并添加索引记录/// </summary>/// <typeparam name="TIndex"></typeparam>/// <param name="indexDir"></param>/// <param name="indexData"></param>/// <param name="setDocFiledsAction"></param>public static void AddIndex<TIndex>(string indexDir, TIndex indexData, Action<Document, TIndex> setDocFiledsAction){//创建索引⽬录if (!System.IO.Directory.Exists(indexDir)){System.IO.Directory.CreateDirectory(indexDir);}FSDirectory directory = FSDirectory.Open(new DirectoryInfo(indexDir), new NativeFSLockFactory());bool isUpdate = IndexReader.IndexExists(directory);if (isUpdate){//如果索引⽬录被锁定(⽐如索引过程中程序异常退出),则⾸先解锁if (IndexWriter.IsLocked(directory)){IndexWriter.Unlock(directory);}}using (IndexWriter writer = new IndexWriter(directory, new PanGuAnalyzer(), !isUpdate, IndexWriter.MaxFieldLength.UNLIMITED)){Document document = new Document();setDocFiledsAction(document, indexData);writer.AddDocument(document);writer.Optimize();//优化索引}}/// <summary>/// 删除索引记录/// </summary>/// <param name="indexDir"></param>/// <param name="keyFiledName"></param>/// <param name="keyFileValue"></param>public static void DeleteIndex(string indexDir, string keyFiledName, object keyFileValue){FSDirectory directory = FSDirectory.Open(new DirectoryInfo(indexDir), new NativeFSLockFactory());if (!IndexReader.IndexExists(directory)){return;}using (IndexWriter iw = new IndexWriter(directory, new PanGuAnalyzer(), IndexWriter.MaxFieldLength.UNLIMITED)){iw.DeleteDocuments(new Term(keyFiledName, keyFileValue.ToString()));iw.Optimize();//删除⽂件后并⾮从磁盘中移除,⽽是⽣成⼀个.del的⽂件,需要调⽤Optimize⽅法来清除。
映射驱动器Y: 192.168.18.2\o user user注意Java命名规范,写程序时一定要注释!改变MyEclips编辑器字体window→preferences→Appearance→Colors and Fonts→Java Editor Text Font在MyEclipse里查看类源码:D:\Program Files\Java\jdk1.5.0里src.zip解压到D:\Program Files\Java\jdk1.5.0\lib\src里,然后在MyEclipse里点击需要查看的类库中的类源码,按F3,如System后(第一次时需复制路径D:\Program Files\Java\jdk1.5.0\lib\src),会产生System.class的选项卡。
将文件拖到运行里或命令窗口中,可查看文件全路径(此方法可查看扩展名)。
反编译工具,将.class文件反统成.java文件,见张孝祥JA V A基础1.WMV末。
第一章划时代的Java语言安装jdk_1.5后Java环境变量配置:从【开始】→【设置】→【控制面板】→【系统】→【高级】→【环境变量】→【系统变量】,或者我的电脑→属性→高级→环境变量→系统变量然后到【新建】。
1.JA V A_HOME = D:\Program Files\Java\jdk1.5.02.PA TH = %JA V A_HOME%\bin;3.CLASSPA TH= .;%JA V A_HOME%\lib\dt.jar;%JA V A_HOME%\lib\tool s.jar;看好是在:“系统变量”中!!控制台里输入java –version 查看java版本一个Java程序源文件只能有一个类是public的(主类),main函数在主类里(才能运行),并且该类的类名和文件命名要完全一致,包括大小写。
每个源文件中的class类都将被编译成一个.class字节码文件,(有多少类就有多少.class字节码文件)这就是类文件。
《互联网软件应用与开发》实验指导书目录一、Java语言实验机器与环境 (1)(一)计算机的硬件配置 (1)(二)计算机的软件配置 (1)二、JDK1.3.1的安装和设置 (1)(一)下载JDK1.3.1 (1)(二)安装JDK1.3.1 (1)(三)配置环境变量 (6)(四)测试安装 (7)三、JDK开发工具简介 (7)四、Java程序开发步骤 (7)(一)编辑 (8)(二)编译 (8)(三)运行 (8)五、上机实验 (8)实验1:学会简单的开发 (8)1.实验目的 (8)2.实验内容 (9)实验2:Java程序控制 (10)1.实验目的 (10)2.实验内容 (10)实验3:由键盘输入数据 (12)1.实验目的 (12)2.实验内容 (12)实验4:类与方法 (13)1.实验目的 (13)2.实验内容 (13)实验5:一个实用的Java Applet (14)1.实验目的 (14)2.实验内容 (15)实验6:多线程与异常处理 (16)1.实验目的 (16)2.实验内容 (16)一、Java语言实验机器与环境(一)计算机的硬件配置PC系列微机,包括286、386、486、奔腾及各种兼容机,要求内存为64M 以上,一个硬盘驱动器和一个软盘驱动器。
80列字符监视器。
配备鼠标器。
(二)计算机的软件配置DOS6.22或Windows 98、Windows xp、Windows 2000。
JDK1.3.1的安装软件j2sdk-1_3_1_02-win.exe二、JDK1.3.1的安装和设置(一)下载JDK1.3.1JDK开发工具包可以免费下载。
下载网址——/product下载如下文件:j2sdk-1_3_1_02-win.exe。
(二)安装JDK1.3.1由于目前大多数用户使用的是Window 98 操作系统,所以我们以在Window 98 操作系统上安装JDK1.3.1为例,说明安装JDK1.3.1的过程。
Compass技术文档目录一、原理描述:.................................................................................................................................二、术语解释:.................................................................................................................................三、下载地址:.................................................................................................................................四、使用流程: …………………………………………………………………………………….五、基于SSH的compass的实例: …………………………………………………………………一、原理描述:Compass是一流的开放源码JAVA搜索引擎框架,对于你的应用修饰,搜索引擎语义更具有能力。
依靠顶级的Lucene搜索引擎,Compass 结合了,像Hibernate和Spring的流行的框架,为你的应用提供了从数据模型和数据源同步改变的搜索力.并且添加了2方面的特征,事物管理和快速更新优化.Compass的目标是:把java应用简单集成到搜索引擎中.编码更少,查找数据更便捷.二、术语解释:三、下载地址:四、使用流程:五、基于SSH的compass的实例:step1在ssh2的基础上开发加入jar包(compass-2.1.2.jar compass-index-patch.jarlucene-analyzers-2.4.0.jar lucene-core-2.4.0.jar lucene-highlighter-2.4.0.jar paoding-analysis.jar)step2先来看下实体bean的编写Java代码1.package com.v512.example.model;2.import pass.annotations.*;3./**4. * Product entity.5. *6. * @author MyEclipse Persistence Tools7. */8.@Searchable9.public class Product implements java.io.Serializable {10.11. // Fields13. @SearchableId14. private String id;15. @SearchableProperty(name="name",index=Index.ANALYZED,store=Store.YES)16. private String name;17. @SearchableProperty(name="price",index=Index.NOT_ANALYZED,store=Store.YES)18. private Double price;19. @SearchableProperty(name="brand",index=Index.ANALYZED,store=Store.YES)20. private String brand;21. @SearchableProperty(name="description",index=Index.ANALYZED,store=Store.YES)22. private String description;23.24. // Constructors25.26. /** default constructor */27. public Product() {28. }29.30. /** full constructor */31. public Product(String name, Double price, String brand, String description) {32. = name;33. this.price = price;34. this.brand = brand;35. this.description = description;36. }37.38. // Property accessors39.40. public String getId() {41. return this.id;42. }43.44. public void setId(String id) {45. this.id = id;46. }47.48. public String getName() {49. return ;50. }52. public void setName(String name) {53. = name;54. }55.56. public Double getPrice() {57. return this.price;58. }59.60. public void setPrice(Double price) {61. this.price = price;62. }63.64. public String getBrand() {65. return this.brand;66. }67.68. public void setBrand(String brand) {69. this.brand = brand;70. }71.72. public String getDescription() {73. return this.description;74. }75.76. public void setDescription(String description) {77. this.description = description;78. }79.80.}step3属性文件Product.hbm.xmlJava代码1.<?xml version="1.0" encoding="utf-8"?>2.<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"3."/hibernate-mapping-3.0.dtd">4.<!--5. Mapping file autogenerated by MyEclipse Persistence Tools6.-->7.<hibernate-mapping>8. <class name="com.v512.example.model.Product" table="PRODUCT" >9. <id name="id" type="ng.String">10. <column name="ID" length="40" />11. <generator class="uuid.hex" />12. </id>13. <property name="name" type="ng.String">14. <column name="NAME" length="80" />15. </property>16. <property name="price" type="ng.Double">17. <column name="PRICE" precision="6" />18. </property>19. <property name="brand" type="ng.String">20. <column name="BRAND" length="40" />21. </property>22. <property name="description" type="ng.String">23. <column name="DESCRIPTION" length="2000" />24. </property>25. </class>26.</hibernate-mapping>要使用Compass必须加入一个applicationContext-compass.xml文件,文件名可以自行定义这个就不用说了废话step4applicationContext-compass.xml:Java代码1.<?xml version="1.0" encoding="UTF-8"?>2.3.<beans xmlns="/schema/beans"4. xmlns:xsi="/2001/XMLSchema-instance"5. xsi:schemaLocation=" /schema/beans /schema/beans/spring-beans -2.5.xsd"6. default-lazy-init="true">7.8. <!-- 配置compass的注解功能 -->9. <bean id="annotationConfiguration"10. class="passAnnotationsConfiguration">11. </bean>12.13.14. <bean id="compass" class="pass.spring.LocalCompassBean">15. <!-- 配置需要索引的实体映射文件的路径 -->16. <property name="resourceDirectoryLocations">17. <list>18. <value>classpath:com/v512/example/model</value>19. </list>20. </property>21. <!-- 设置存放索引的路径 -->22. <property name="connection">23. <value>/lucene/indexes</value>24. </property>25.26. <!--配置要搜索的类,作用:会根据以下的类建立索引 -->27. <property name="classMappings">28. <list>29. <value>com.v512.example.model.Product</value>30. </list>31. </property>32. <property name="compassConfiguration"33. ref="annotationConfiguration" />34.35. <!--compass的一些属性设置 -->36. <property name="compassSettings">37. <props>38. <prop key="compass.transaction.factory">39. pass.spring.transaction.SpringSyncTransactionFactory40. </prop>41. <prop key="compass.engine.analyzer.MMAnalyzer.CustomAnalyzer">net.paoding.analysis.analyzer.PaodingAnalyzer </prop>42. </props>43. </property>44. <!--compass的事务管理器 -->45. <property name="transactionManager" ref="transactionManager" />46. </bean>47.48.49. <bean id="hibernateGpsDevice"50. class="pass.gps.device.hibernate.HibernateGpsDevice">51. <property name="name">52. <value>hibernateDevice</value>53. </property>54. <property name="sessionFactory" ref="sessionFactory" />55. <property name="mirrorDataChanges">56. <value>true</value>57. </property>58. </bean>59. <!-- 同步更新索引 -->60. <bean id="compassGps" class="pass.gps.impl.SingleCompassGps"61. init-method="start" destroy-method="stop">62. <property name="compass" ref="compass" />63. <property name="gpsDevices">64. <list>65. <bean66. class="pass.spring.device.SpringSyncTransactionGpsDeviceWrapper">67. <property name="gpsDevice" ref="hibernateGpsDevice" />68. </bean>69. </list>70. </property>71. </bean>72.73.74. <bean id="compassTemplate"75. class="passTemplate">76. <property name="compass" ref="compass" />77. </bean>78.79. <!-- 定时重建索引(利用quartz)或随Spring ApplicationContext启动而重建索引 -->80. <bean id="compassIndexBuilder"81. class="passIndexBuilder"82. lazy-init="false">83. <property name="compassGps" ref="compassGps" />84. <property name="buildIndex" value="true" />85. <property name="lazyTime" value="10" />86. </bean>87.88.89.90.</beans>中间都有注解就不多解释了下面来编写dao及dao的实现以及severce层step5Java代码1.package com.v512.example.dao;2.3.import java.util.List;4.5.import com.v512.example.model.Product;6.7.public interface ProductDao {8. public void create(Product p);9. public Product getProduct(String id);10. public List getProducts();11. public void update(Product product);12. public void remove(String id);13.14.}Java代码1.package com.v512.example.dao.hibernate;2.3.import java.util.List;4.5.import com.v512.example.dao.ProductDao;6.import com.v512.example.model.Product;7.import org.springframework.orm.hibernate3.support.HibernateDaoSupport;8.public class ProductDaoHibernate extends HibernateDaoSupport implements ProductDao {9.10. public void create(Product p) {11. getHibernateTemplate().save(p);12.13. }14.15. public Product getProduct(String id) {16. return (Product)getHibernateTemplate().get(Product.class, id);17. }18.19. public List getProducts() {20. return getHibernateTemplate().find("from Product order by id desc");21. }22.23. public void remove(String id) {24. getHibernateTemplate().delete(getProduct(id));25.26. }27.28. public void update(Product product) {29. getHibernateTemplate().saveOrUpdate(product);30.31. }32.33.}serveceJava代码1.package com.v512.example.service;2.3.import java.util.List;4.5.import com.v512.example.model.Product;6.7.public interface ProductManager {8. public void insertProduct(Product p);9. public Product findProdcut(String id);10. public List searchProducts(String queryString);11.12.13.}servece的实现Java代码1.package com.v512.example.service.impl;2.3.import java.util.ArrayList;4.import java.util.List;5.6.import passHits;7.import passSession;8.import passTemplate;9.import passTransaction;10.11.import com.v512.example.dao.ProductDao;12.import com.v512.example.model.Product;13.import com.v512.example.service.ProductManager;14.import pass;15.public class ProductManagerImpl implements ProductManager {16. private ProductDao productDao;17. private CompassTemplate compassTemplate;18.19.20.21.22. public void setCompassTemplate(CompassTemplate compassTemplate){23. passTemplate=compassTemplate;24. }25.26. public void setProductDao(ProductDao productDao){27. this.productDao=productDao;28. }29.30. public Product findProdcut(String id) {31. return productDao.getProduct(id);32. }33.34. public void insertProduct(Product p) {35. productDao.create(p);36. }37.38. public List searchProducts(String queryString) {39. Compass compass = compassTemplate.getCompass();40. CompassSession session=compass.openSession();41. List list = new ArrayList();42. //这里不需要开启事务了,因为在调用这个方法之前就已经开启了事务43. CompassHits hits= session.queryBuilder().queryString("name:"+queryString).toQuery().hits();44. System.out.println("queryString:"+queryString);45. System.out.println("hits:"+hits.getLength());46. for(int i=0;i<hits.length();i++){47. Product hit=(Product)hits.data(i);48. list.add(hit);49. }50.51. return list;52. }53.54.55.56. public CompassTemplate getCompassTemplate() {57. return compassTemplate;58. }59.60.}所有的都做完了现在编写jsp页面step6insertProduct.jspJava代码1.<%@ page language="java" contentType="text/html; charset=UTF-8"2. pageEncoding="UTF-8"%>3.<%@ taglib prefix="s" uri="/struts-tags"%>4.<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN""/TR/html4/loose.dtd">5.<html>6.<head>7.<meta http-equiv="Content-Type" content="text/html; charset=utf-8">8.<link href="style/oa.css" rel="stylesheet" type="text/css"> 9.10.<title>添加信息</title>11.</head>12.<body>13.<center>14. <s:form action="insert.action" theme="simple">15.16.<TABLE class="tableEdit" border="0" cellspacing="1" cellpadding="0" style="width:300px;">17. <TBODY>18. <TR>19. <td align="center" class="tdEditTitle">添加商品名称</TD>20. </TR>21. <TR>22. <td>23.24.25.<table class="tableEdit" style="width:300px;" cellspacing="0" border="0" cellpadding="0">26. <tr>27. <td class="tdEditLabel" >商品名称</td>28. <td class="tdEditContent"><s:textfield name="product.name" label="名称" /></td>29. </tr>30.31. <tr>32. <td class="tdEditLabel" >商品品牌</td>33. <td class="tdEditContent"><s:textfield name="product.brand" label="品牌" /></td>34. </tr>35.36. <tr>37. <td class="tdEditLabel" >商品价格</td>38. <td class="tdEditContent"><s:textfield name="product.price" label="价格" /></td>39. </tr>40.41. <tr>42. <td class="tdEditLabel" >商品描述</td>43. <td class="tdEditContent"><s:textarea name="product.description" label="描述" />44. </td>45. </tr>46. <tr>47. <td> 48. </td>49. <td><s:submit/>50. <br></td>51. </tr>52.</table>53. </td>54. </TR>55. </TBODY>56.</TABLE>57.</s:form>58.</center>59.</body>60.</html>step7编写actionJava代码1.package com.v512.example.action;2.3.import java.util.List;4.5.import com.opensymphony.xwork2.ActionSupport;6.import com.v512.example.model.Product;7.import com.v512.example.service.ProductManager;8.import org.apache.struts2.ServletActionContext;9.10.public class ProductAction extends ActionSupport {11.12. private static final long serialVersionUID = 3795048906805728732L;13. private ProductManager productManager;14. private Product product;15. private String queryString;16.17. public void setQueryString(String queryString){18. this.queryString=queryString;19. }20.21. public Product getProduct() {22. return product;23. }24.25. public void setProduct(Product product) {26. this.product = product;27. }28.29. public void setProductManager(ProductManager productManager){30. this.productManager=productManager;31. }32.33. public String insert(){34. productManager.insertProduct(product);35. return SUCCESS;36. }37. public String search(){38. List results=productManager.searchProducts(queryString);39. System.out.println(results.size());40. ServletActionContext.getRequest().setAttribute("searchresults", results);41. return SUCCESS;42. }43.44.45.}step8关于Struts2的配置文件如下Java代码1.<?xml version="1.0" encoding="UTF-8" ?>2.<!DOCTYPE struts PUBLIC3. "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"4. "/dtds/struts-2.0.dtd">5.6.<struts>7. <constant name="struts.objectFactory" value="spring" />8.9. <include file="struts-default.xml"/>10.11. <package name="product" extends="struts-default"12. namespace="/product">13.14. <!-- 配置Struts2的Action,class值要与applicationContext*.xml中的id的值一致。
+ Basic Actions能加入到程序中的基本Action - Go to跳转到指定的帧- Play播放- Stop停止- Toggle High Quality在高画质和低画质间切换- Stop All Sounds停止所有声音的播放- Get URL使浏览器浏览指定页面- FSCommand发送FSCommand命令- Load Movie引入影片- Unload Movie卸载影片- Tell Target指定Action命令生效的目标- If Frame Is Loaded..帧是否被载入- On Mouse Event鼠标事件+ Actions所有的Action- break跳出循环- call调用指定帧- comment注释- continue继续循环- delete删除一个物件(Object)中的变量- do while do while循环- duplicateMovieClip复制MC- else否则(与if联用)- else if否则如果(与if联用)- evaluate调用自己写的函数(Function)- for for循环- for .. in列举物件(Object)中的子体(Child)- FSCommand发送FSCommand命令- function声明自定义函数- getURL使浏览器浏览指定页面- goto跳转到指定的帧- if如果- ifFrameLoaded..帧是否被载入- include读入外部的ActionScript程序文件(.as) - loadMovie引入MC- loadVariables引入外部文件中的变量值- on鼠标事件的触发条件- onClipEvent MC的事件触发程序- play播放- print输出到打印机- removeMovieClip删除MC- return在函数(function)中返回一个值- set variable设定变量值- setProperty设定属性- startDrag开始拖动- stop停止- stopAllSounds停止所有声音的播放- stopDrag停止拖动- swapDepths交换两个MC的深度- tellTarget指定Action命令生效的目标- toggleHighQuality在高画质和低画质间切换- trace跟踪调试- unloadMovie卸载MC- var声明局部变量- while当..成立时..- with对..物件(Object)做..+ Operators- !逻辑非操作- !=不等于- ""字符串- %取余数- &&逻辑与操作- ()括号- *乘号-+ 加号-+ +变量自加一- -减号- --变量自减一- /除号- <小于- <=小于等于- <>不等于- ==相等- >大于- >=大于等于- and逻辑与- not逻辑非- or逻辑或- typeof返回变量类型- void实体,无返回- | |逻辑或操作+ Bitwise Operators位操作符- &位与操作- <<位左移- >>位右移- >>>位右移(无符号)- ^位异或操作- |位或操作- ~补位操作+ Compound Assign Operators复合操作符- %=A%=B 等效于A=A%B- &=A&=B 等效于A=A&B- *=A*=B 等效于A=A*B-+ =A+=B 等效于A=A+B- -=A-=B 等效于A=A-B- /=A/=B 等效于A=A/B- <<=A<<=B 等效于A=A<<B- >>=A>>=B 等效于A=A>>B- >>>=A>>>=B 等效于A=A>>>B- ^=A^=B 等效于A=A^B- |=A|=B 等效于A=A|B+ String Operators字符串操作符- add连接两个字符串- eq A eq B 字符串A值与字符串值B相等- ge A ge B 字符串A值大于等于字符串B值- gt A gt B 字符串A值大于字符串B值- le A le B 字符串A值小于等于字符串B值- lt A lt B 字符串A值小于字符串B值- ne A ne B 字符串A值不等于字符串B值+ Functions函数- Boolean取表达式的布尔值(True 或False)- escape除去URL串中的非法字符- eval返回由表达式命名的变量得值- false布尔非值(0)- getProperty获取属性- getTimer获取从电影开始播放到现在的总播放时间(毫秒数) - getVersion获取浏览器的FLASHPlayer的版本号- globalToLocal场景(Scene)中的坐标转换成MC中的坐标- hitTest测试一个点或者MC是否同另一个交叉- int把数值强制转换成整数- isFinite测试数值是否为有限数- isNaN测试是否为非数值- keycode返回键盘按下键的键盘值- localToGlobal MC中的坐标转换成场景(Scene)中的坐标- maxscroll文本框的最大长度- newline换行符- Number将参数转换成数值- parseFloat将字符串转换成浮点数- parseInt将字符串转换成小数- random产生0到指定数间的随机数- scroll文本框中的当前行- String将参数转换成字符串- targetPath返回指定实体MC的路径字符串- true布尔是值(1)- unescape保留字符串中的%XX格式的十六进制字符+ String Functions字符串函数- chr将ASCII码转换成相应字符- length返回字符串的长度- mbchr将ASCII/S-JIS编码转换成相应的多字节字符- mblength返回多字节字符串的长度- mbord将多字节字符转换成相应的ASCII/S-JIS编码- mbsubstring截取多字节字符串中的字串- ord将字符转换成ASCII码- substring截取字符串中的子串+ Properties属性- _alpha Alpha值(透明度值)- _currentframe在MC中的当前帧数- _droptarget正在拖动的MC是否播完- _focusrect焦点矩形框的显示与否(True显示/Flase不显示)- _framesloaded载入的影帧数- _height MC的高度- _highquality画质的高低(True高画质/False低画质)- _name MC的实体名- _quality当前画质(字符串值) LOW,MEDIUM,HIGH,BEST- _rotation MC旋转的角度(单位:度)- _soundbuftime声音的缓冲区大小(默认值5,单位:秒)- _target MC的路径- _totalframes总帧数- _url电影被调用的URL地址- _visible是否可视(True可视/False不可视)- _width MC的宽度- _x MC的x坐标- _xmouse鼠标的x坐标- _xscale MC的X轴向缩放度- _y MC的y坐标- _ymouse鼠标的y坐标- _yscale MC的y轴向缩放度+ Objects物件+ Array数组- concat合并多个数组- join合并数组元素位字符串- length返回数组长度- new Array新建数组物件- pop出栈(FILO 先入后出)- push入栈(入队列)- reverse反相(颠倒数组,及第一个元素和最后一个元素互换……) - shift出队列(FIFO 先入先出)- slice截取数组中的子串生成新的数组- sort数组元素的排序- splice从数组中指定元素起删除指定个数的元素或者删除指定元素- unshift从数组头部插入一个元素+ Boolean布尔数- new Boolean新建布尔型物件- toString将布尔型物件的值转换成字符串值- valueOf获取布尔型物件的值(返回值为布尔型)+ Color颜色- getRGB获取颜色值的RGB分量(返回值0xRRGGBB十六进制)- getTransform获取颜色值的转换量(返回值cxform 型)[不太清楚] - new Color新建一颜色物件- setRGB设置颜色值的RGB分量(参数为0xRRGGBB十六进制)- setTransform设置颜色值的转换量(参数为cxform 型)[不太清楚]+ Date时间和日期- getDate获取当前日期(本月的几号)- getDay获取今天是星期几(0-Sunday,1-Monday...)- getFullYear获取当前年份(四位数字)- getHours获取当前小时数(24小时制,0-23)- getMilliseconds获取当前毫秒数- getMinutes获取当前分钟数- getMonth获取当前月份(注意从0开始:0-Jan,1-Feb...)- getSeconds获取当前秒数- getTime获取UTC格式的从1970.1.1 0:00以来的秒数- getTimezoneOffset获取当前时间和UTC格式的偏移值(以分钟为单位) - getUTCDate获取UTC格式的当前日期(本月的几号)- getUTCDay获取UTC格式的今天是星期几(0-Sunday,1-Monday...)- getUTCFullYear获取UTC格式的当前年份(四位数字)- getUTCHours获取UTC格式的当前小时数(24小时制,0-23)- getUTCMilliseconds获取UTC格式的当前毫秒数- getUTCMinutes获取UTC格式的当前分钟数- getUTCMonth获取UTC格式的当前月份(注意从0开始:0-Jan,1-Feb...) - getUTCSeconds获取UTC格式的当前秒数- getYear获取当前缩写年份(当前年份减去1900)- new Date新建日期时间物件- setDate设置当前日期(本月的几号)- setFullYear设置当前年份(四位数字)- setHours设置当前小时数(24小时制,0-23)- setMilliseconds设置当前毫秒数- setMinutes设置当前分钟数- setMonth设置当前月份(注意从0开始:0-Jan,1-Feb...)- setSeconds设置当前秒数- setTime设置UTC格式的从1970.1.1 0:00以来的秒数- setUTCDate设置UTC格式的当前日期(本月的几号)- setUTCFullYear设置UTC格式的当前年份(四位数字)- setUTCHours设置UTC格式的当前小时数(24小时制,0-23)- setUTCMilliseconds设置UTC格式的当前毫秒数- setUTCMinutes设置UTC格式的当前分钟数- setUTCMonth设置UTC格式的当前月份(注意从0开始:0-Jan,1-Feb...) - setUTCSeconds设置UTC格式的当前秒数- setYear设置当前缩写年份(当前年份减去1900)- toString将日期时间值转换成"日期/时间"形式的字符串值- UTC返回指定的UTC格式日期时间的固定时间值+ Key键盘- BACKSPACE Backspace(<-)键- CAPSLOCK CapsLock键- CONTROL Ctrl键- DELETEKEY Delete(Del)键- DOWN方向下键- END End键- ENTER Enter(回车)键- ESCAPE Esc键- getAscii获取最后一个按下或松开的键的对应字符的Ascii码- getCode获取最后一个被按下的键的键盘扫描码- HOME Home键- INSERT Insert(Ins)键- isDown当指定键被按下时返回True值- isToggled当指定键被锁定时返回True值- LEFT方向左键- PGDN PageDown(PGDN)键- PGUP PageUp(PGUP)键- RIGHT方向右键- SHIFT Shift键- SPACE空格键- TAB Tab键- UP方向上键+ Math数学函数- abs abs(n) 取n的绝对值- acos acos(n) n的反余弦(返回值单位:弧度)- asin asin(n) n的反正弦(返回值单位:弧度)- atan atan(n) n的反正切(返回值单位:弧度)- atan2atan2(x,y) 计算x/y的反正切- ceil ceil(n) 取靠近n的上限的整数(向上取整)- cos cos(n) 取n的余弦(n的单位:弧度)- E Euler(欧拉)指数(约为2.718)- exp指数- floor floor(n) 取靠近n的下限的整数(向下取整)- LN10ln10(约等于2.302)- LN2ln2(约等于0.693)- log取自然对数(e为底)- LOG10E10为底取E的对数(约等于0.434)- LOG2E2为底取E的对数(约等于1.443)- max返回两参数中的最大值- min返回两参数中的最小值- PI圆周率(约等于3.14159)- pow pow(x,y) x的y次方- random产生0-1间的随机数- round四舍五入取整- sin sin(n) 取n的正弦(n的单位:弧度)- sqrt开根号- SQRT1_20.5开根号(约等于0.707)- SQRT22开根号(约等于1.414)- tan tan(n) 取n的正切(n的单位:弧度)+ MovieClip电影剪辑- attachMovie绑定一个电影,产生一个库中MC的实体- dupicateMovieClip复制当前MC为新的MC- getURL使浏览器浏览指定页面- gotoAndPlay跳转到指定帧并播放- gotoAndStop跳转到指定帧并停止播放- loadMovie引入一个外部电影到指定层- loadVariables引入外部文件中的变量值- nextFrame下一帧- play播放- prevFrame前一帧- removeMovieClip删除用duplicateMovieClip创建的MC- startDrag开始拖动MC- stop停止MC的播放- stopDrag停止拖动MC- unloadMovie卸载由loadMovie引入的Movie+ Mouse鼠标- hide隐藏鼠标指针- show显示鼠标指针+ Number数值- MAX_V ALUE FLASH5 所允许的最大数值1.79769313486231 e 308 - MIN_V ALUE FLASH5 所允许的最小数值5 e -324- NaN是否为非数值(Not a Number)- NEGATIVE_INFINITY是否为负数- new Number新建数值物件- POSITIVE_INFINITY是否为正数- toString将数值转换成字符串+ Object物件- new Object新建物件- toString转换物件为字符串- valueOf返回物件的值+ Selection选择区- getBeginIndex获取可编辑文本区的起始位置,-1表示无可编辑文本区- getCaretIndex获取当前的编辑位置,-1表示没有可编辑文本区- getEndIndex获取可编辑文本区的结束位置,-1表示无可编辑文本区- getFocus获取当前的激活文本区的文本变量名- setFocus设置当前的激活文本区- setSelection设置可编辑文本的起始位置和终止位置+ Sound声音- attachSound绑定库中的一个声音- getPan获取声音的混音值[不太清楚]- getTransform获取当前声音的变换量(返回值类型:sxform)[不太清楚]- getV olume获取当前声音的音量(百分比)- new Sound新建声音物件- setPan设置声音的混音值[不太清楚]- setTransform设置当前声音的变换量(参数类型:sxform)[不太清楚]- setVloume设置当前声音的音量(百分比)- start开始播放当前声音- stop停止播放当前声音+ String字符串- charAt在指定的索引表中返回一个字符- charCodeAt在指定的索引表中返回一个字符的代码- concat联结合并多个字符串- fromCharCode从字符代码组构造出一个新的字符串- indexOf在字符串中寻找子串,返回子串起始位置或-1(-1表示未找到)- lastIndexOf在字符串中寻找子串,返回子串终止位置或-1(-1表示未找到)- length返回字符串的长度- new String新建字符串物件- slice 返回字符串中指定截取的子串- split根据限定符将字符串转换成一个数组- substr substr( start, length ) 返回从start开始,共length长的子串- substring substring( indexA, indexB ) 返回indexA..indexB之间的子串- toLowerCase将字符串中的大写字符全部转换成小写- toUpperCase将字符串中的小写字符全部转换成大写+ XML可扩充性标记语言- appendChild添加一个子结点到指定的XML元素- attributes XML元素的属性数组- childNodes一个XML元素的子结点数组- cloneNode克隆(复制)当前结点- createElement新建一个新的XML元素- createTextNode 新建一个新的XML文本结点- firstChild返回当前XML结点的第一个子结点- hasChildNodes当前XML结点是否有子结点(返回true有子结点/flash则无)- insertBefore在一个指定的XML元素的子结点前插入一个新的子结点- lastChild返回当前XML结点的最后一个子结点- load从指定的URL把XML元素引入FLASH中- loaded当XML元素引入或是发送同时引入FLASH中后,返回true值- new XML新建一个XML物件- nextSibling当前XML结点的下一个结点- nodeName返回当前XML结点的名字- nodeType返回当前XML结点的类型(1-元素,3-文本)- nodeValue返回当前XML结点的值(text型返回文本)- onLoad当引入或发送同时引入时触发事件- parentNode返回当前XML结点的父结点- par***ML将XML字符串转换成XML物件- previousSibling当前XML结点的前一个结点- removeNode从XML文本中删除结点- send从FLASH中把一个XML元素发送到指定的URL地址- sendAndLoad从FLASH中把一个XML元素发送到指定的URL地址同时引入XML结果- toString把XML物件转换为XML字符串表达+ XMLSocket XML套接口- close关闭一个XML套接口- connect连接一个XML套接口,指定URL,并定义其端口号- new XMLSocket建立一个新的XML套接口- onClose关闭XML套接口时触发事件- onConnect连接XML套接口时触发事件- onXML从服务器上获取XML时触发事件- send发送XML给服务器约定称谓:---------------------------------------variable 变量,可为数值、布尔值或字符串。
Java2实⽤教程(第五版)1(第1章)⼀、问答题1.James Gosling2.需3个步骤:⽤⽂本编辑器编写源⽂件。
使⽤javac编译源⽂件,得到字节码⽂件。
使⽤解释器运⾏程序。
3.由类所构成,应⽤程序必须有⼀个类含有public static void main(String args[])⽅法,含有该⽅法的类称为应⽤程序的主类。
不⼀定,但最多有⼀个public类。
4.set classpath=D:\jdk\jre\lib\rt.jar;.;5. java和class6. java Bird7. 独⾏风格(⼤括号独占⾏)和⾏尾风格(左⼤扩号在上⼀⾏⾏尾,右⼤括号独占⾏)⼆、选择题1.B。
2.D。
三、阅读程序1.(a)Person.java。
(b)两个字节码,分别是Person.class和Xiti.class。
(c)在类Person中找不到main⽅法;找不到或⽆法加载主类;找不到或⽆法加载主类;您好,很⾼兴认识你nice to meet you2(第2章)⼀、问答题1.⽤来标识类名、变量名、⽅法名、类型名、数组名、⽂件名的有效字符序列称为标识符。
标识符由字母、下划线、美元符号和数字组成,第⼀个字符不能是数字。
false不是标识符。
2.关键字就是Java语⾔中已经被赋予特定意义的⼀些单词,不可以把关键字作为名字来⽤。
不是关键字。
class implements interface enum extends abstract。
3.boolean,char,byte,short,int,long,float,double。
4.float常量必须⽤F或f为后缀。
double常量⽤D或d为后缀,但允许省略后缀。
5.⼀维数组名.length。
⼆维数组名.length。
⼆、选择题1.C。
2.ADF。
3.B。
4.BE。
5.【代码2】【代码3】【代码4】【代码5】。
6.B。
三、阅读或调试程序4.【代码1】:4。
lucene语法Lucene语法是Apache的一种全文搜索引擎,它使用基于文本的搜索查询语言,称为Lucene语法,来进行搜索。
Lucene语法允许用户查找文档中出现了哪些字词,以及这些字词出现的频率,如果允许从各类文本文件中搜索,它将非常有用。
Lucene语法是一种简单易懂的搜索语言,可以让用户指定一个或多个关键字来搜索文档,有可能搜索语句会比较复杂,可以搜索标题、内容和文档属性。
同时,用户还可以指定搜索的范围(例如标题、内容等),以及搜索的结果排序方式等。
Lucene语法使用简单的条件来搜索文档中的文本,其中的查询条件可以通过一些关键词来表示,比如AND(与)、OR(或)、NOT(非)、+(前缀词)、-(后缀词)等。
其中,AND可以表示必须满足所有条件;OR是至少满足任一条件;NOT可以排除结果中包含某个特定词汇的文档;在+号和-号前加上关键词可以指定该词必须出现或不能出现。
Lucene语法还支持括号、引号等形式,括号可以将查询条件分组,指定查询运算符的优先级,例如要搜索字词“lion”和“tiger”,但不搜索“leopard”,就可以使用“lion OR tiger -leopard”的格式;引号可以搜索完整的词组。
Lucene语法有一些限制,搜索语句不能超过1024个字符,搜索语句中总字数(不含空格)不能超过4096个字符,每个空格也算一个字符。
Lucene语法有很多优点,比如它可以根据文档的字词的频率和位置来确定文档的相关度,这样可以提高搜索的准确性,另外它还支持多种操作符,可以简化搜索语句,增加搜索的准确性。
总的来说,Lucene语法是一种全文搜索引擎的搜索语言,它使用简单易懂的语句,使用它可以更准确地搜索文档,比如可以搜索多个关键字,可以指定搜索的范围,以及搜索的结果排序方式等,因此Lucene语法在全文搜索领域非常重要。
HNSW(Hierarchical Navigable Small World)是一种高效的最近邻搜索算法,常用于高维空间数据的搜索。
Lucene是一个广泛使用的文本搜索引擎库,提供了HNSWGraphSearcher的实现。
以下是一个使用Lucene HNSWGraphSearcher的示例:首先,确保你已经将Lucene的依赖项添加到项目中。
然后,你可以使用以下代码创建一个HNSWGraphSearcher实例并执行搜索:```javaimport org.apache.lucene.search.HNSWGraphSearcher;import org.apache.lucene.search.Query;import org.apache.lucene.index.DirectoryReader;import org.apache.lucene.store.RAMDirectory;import org.apache.lucene.index.IndexReader;public class HNSWGraphSearcherExample {public static void main(String[] args) throws Exception {// 创建一个RAMDirectory实例,用于存储索引数据RAMDirectory indexDir = new RAMDirectory();// 创建一个IndexReader实例,用于读取索引数据IndexReader indexReader = DirectoryReader.open(indexDir);// 创建一个HNSWGraphSearcher实例HNSWGraphSearcher searcher = new HNSWGraphSearcher(indexReader, 100, 5000);// 创建一个查询实例Query query = new Query();// 设置查询的文本query.setQueryString("Lucene HNSWGraphSearcher Example");// 执行搜索并获取结果TopDocs results = searcher.search(query, null, 10);// 处理搜索结果for (ScoreDoc hit : results.scoreDocs) {System.out.println(hit.score + " - " + indexReader.document(hit.doc).get("text"));}// 关闭资源indexReader.close();indexDir.close();}}```在这个示例中,我们首先创建了一个RAMDirectory实例,用于存储索引数据。
java lambda integer 累加
您可以使用Java Lambda表达式来计算一个整数数组中所有整数的总和。
下面是一个简单的例子:
java复制代码:
import java.util.Arrays;
import java.util.function.IntBinaryOperator;
public class Main {
public static void main(String[] args) {
int[] numbers = {1, 2, 3, 4, 5};
int sum = Arrays.stream(numbers).reduce(0, (a, b) -> a + b);
System.out.println("总和是: " + sum);
}
}
在这个例子中,我们首先创建了一个整数数组numbers,然后使用Arrays.stream()方法将其转换为流。
然后,我们使用reduce()方法来计算流中所有整数的总和。
reduce()方法的第一个参数是累加器的初始值,这里我们设置为0。
第二个参数是一个Lambda表达式,它定义了如何将两个整数相加。
在这个例子中,我们使用(a, b) -> a + b来定义这个操作。
最后,我们打印出总和。
注意,IntBinaryOperator是一个函数式接口,它接受两个int参数并返回一个int结果。
Lucene in Action(简体中文版)共10部分第一部分 Lucene核心1. 接触Lucene2. 索引3. 为程序添加搜索4. 分析5. 高极搜索技术6. 扩展搜索第二部分 Lucene应用7. 分析常用文档格式8. 工具和扩充9. Lucene其它版本10. 案例学习[序章]Lucene开始是做为私有项目。
在1997年末,因为工作不稳定,我寻找自己的一些东西来卖。
Java是比较热门的编程语言,我需要一个理由来学习它。
我已经了解如何来编写搜索软件,所以我想我可以通过用Java 写搜索软件来维持生计。
所以我写了Lucene。
几年以后,在2000年,我意识到我没有销售天赋。
我对谈判许可和合同没有任何兴趣,并且我也不想雇人开一家公司。
我喜欢做软件,而不是出售它。
所以我把Lucene放在SourceForge上,看看是不是开源能让我继续我想做的。
有些人马上开始使用Lucene。
大约一年后,在2001年,Apache提出要采纳Lucene。
Lucene邮件列表中的消息每天都稳定地增长。
也有人开始贡献代码,大多是围绕Lucene的边缘补充:我依然是仅有的理解它的核心的开发者。
尽管如些,Lucene开始成为真正的合作项目。
现在,2004年,Lucene有一群积极的深刻理解其核心的开发者。
我早已不再每天作开发,这个强有力的工作组在进行实质性的增加与改进。
这些年来,Lucene已经翻译成很多其它的语言包括C++、C#、Perl和Python。
在最开始的Java和其它这些语言中,Lucene的应用比我预想的要广泛地多。
它为不同的应用(如财富100公司讨论组、商业Bug跟踪、Microsoft提供的邮件搜索和100页面范围的Web搜索引擎)提供搜索动力。
在业内,我被介绍为“Lucene 人”。
很多人告诉我他们在项目中使用到Lucene。
我依然认为我只听说了使用Lucene的程序的小部分。
如果我当初只是出售它,Lucene应用得不会这么广泛。
程序开发人员看来更喜欢开源。
他们在有问题时不用联系技术支持而只需查看一下源代码。
如果这还不够,邮件列表中的免费支持比大多商业支持要好得多。
类似Lucene的开源项目使得程序开发人员更加有效率。
Lucene通过开源已经变得比我想象的伟大的多。
我见证了它的发展,是Lucene社区的努力才使得它如此兴旺。
Lucene的未来怎样?我无法回答。
有了这本书,你现在也是Lucene社区的一员,现在由您将Lucene带往新的高地。
旅途顺利!DOUG CUTTINGLucene和Nutch的作者前言来自Erik Hatcher在Internet早期我就对搜索和索引感兴趣。
我已经建立了用majordomo、MUSH(Mail User’s Shell)和少量Perl、awk及shell脚本来管理邮件列表的存储结构。
我实现了一个CGI的web接口,允许用户搜索这个列表和其它用户的信息,其内部使用了grep。
然后相继出现了Yahoo!、AltaVista和Excite,这些我都经常访问。
在我有了第一个儿子Jakob之后,我开始了数字照片档案的设计。
我想开发一套管理图片的系统,可以给图片附加元数据,如关键字、拍摄日期。
当然用我选择的尺寸定位图片是很容易的。
在19世纪90年代末,我构建了基于文件系统的原型,使用了Microsoft的技术,包括Microsoft Index Server、Action ServerPages及处理图片的第三方COM组件。
从那时起,我的职业生涯都消耗在这些类似的技术上了。
I was able to cobble together a compelling application in a couple of days of spare-time hacking.我的职业转向Java技术,并且我越来越少地利用Microsoft Windows。
为了以系统无关的方式用Java技术重新实现我的个人照片档案系统及搜索引擎,我使用了Lucene。
Lucene的简单易用远远超过了我的期望—我所期望的其它开源库或工具在概念上简单,但是却难以使用。
在2001年,Steve Loughran和我开始编写Java Development with Ant(Manning)。
我们采用图片搜索引擎的思想,并把它推广为一个文档搜索引擎。
这个程序示例在那本Ant书中使用,而且可被定制为图片搜索引擎。
Ant的责任不仅来自于简单的编译打包的构建过程,也来自于定制的任务,,我们在构建过程中使用Lucene创建索引文件。
Ant任务现在生存在Lucene的Sandbox(沙箱)中,将在本书8.4节描述。
Ant已经应用在我的博客系统中,我称为BlogScene(/erik)。
在建立一个博客实体之后,我运行一个Ant构建过程,索引新的实体并将它们上传到我的服务器上。
我的博客服务器由一个Servlet、一些验证模板和一个Lucene索引组成,允许(rich)查询,甚至联合查询。
与其它博客系统相比,BlogScene在特色和技巧上差很多,但是它的全文检索能力非常强大。
我现在效力于维吉尼亚大学对Patacriticism的应用研究小组()。
我用对文本分析、索引和搜索的经验通过讨论量子力学与艺术的关系来测试及拓展我的思路。
“诗人是世界上不被认可的最伟大的工程师”。
来自Otis Gospodnetic我对信息搜索与管理的兴趣和热情开始于在Middlebury大学的学生时代。
那时候,我发现了信息的广大资源,即Web。
尽管Web仍然刚开始发展,但是对收集、分析、索引和搜索的长期需求是很明显的。
我开始对建立来自Web的信息库感到困惑,开始编写Web爬行器梦想有种方法可以对这些收集的信息进行搜索。
我认为在巨大的未知领域中搜索是杀手级软件。
有了这种思想以后,我开始了一系列收集和搜索项目。
在1995年,和同学Marshall Levin一起创建了WebPh,一个用来收集和找出个人联系信息的开源程序。
基本上,这是一个简单的具有Web接口(CGI)的电话本,那时排在首位的类型。
(实际上,它在19世纪90年代末的案例学习中被引用为一个示例。
)大学和政府机构是这个程序的主要用户,现在还有很多在使用它。
在1997年使用我的WebPh,我继续创建了Populus,一个当时很流行的白页。
尽管技术(与WebPh类似)很普通,但是Populus有很重的负担,并且能够与WhoWhere、Bigfoot和Infospace等大角色相媲美。
在两个关于个人联系信息的项目之后,是该探索新的领域了。
我开始了下一个冒险,Infojump,用来在网上时事通讯、杂志、报纸中选择高质量的信息。
我拥有的软件由大量的Perl模块和脚本组成,Infojump利用一个称作Webinator的Web爬行器和一个全文搜索的产品叫作Texis。
在1998年Infojump提供的服务很像今天的。
尽管WebPh、Populus和Infojump达到了它们的目的并是功能很完善,但它们都有技术的局限性。
它们缺少的是一个用反向索引来支持全文搜索强大的信息搜索库。
为了不重复相同的工作,我开始搜寻一个我认为不可能存在的解决方案。
在2000年早期,我发现了Lucene,我正在寻找的缺少的部分,并且我一下子就喜欢上了它。
我在Lucene还在SourceForge的时候就加入了这个项目,后来2002年Lucene转移到Apache软件基金会。
我对Lucene的热爱是因为这些年来它已经成为我很多思想的核心组件。
这些思想中的一个是Simpy,我最近的一个项目。
Simpy是个有许多特点的个性Web服务,可以让用户加标签、索引、搜索和共享在网上找到的信息。
它主要使用了Lucene,上千条索引,由Doug Cutting的另一个项目Nutch(见第10章)提供动力支持。
我对Lucene的积极参与导致我被邀请与Erik Hatcher共同编写Lucene in Action。
Lucene In Action有关于Lucene最全面的信息。
接下来的10章包含的信息围绕你使用Lucene创建优秀程序所需的所有主题。
这是它平坦且轻快的协作过程的结果,就像Lucene社区一样。
Lucene和Lucene in Action证明了有类似兴趣的人们可以完成什么,不管在人生中会碰到什么情况,都会积极地为全球知识的共享做出贡献。
致谢朋友!首先并且是最重要的,我们感谢我们的妻子Carole(Erik)和Margaret(Otis),一直支持这本书的写作。
没有她们的支持,这本书就不可能出版。
Erik感谢他的两个儿子,Ethan和Jakob,因为他们的忍耐和理解,Erik写这本书时没有时间陪他们玩耍。
我们真诚感谢Doug Cutting。
没有Doug的贡献,就不可能有Lucene。
没有其他Lucene的贡献者,Lucene 就会少很多特征、更多的Bug,Lucene的成长就会花更长的时间。
感谢所有的贡献者,包括Peter Carlson、Tal Dayan、Scott Ganyo、Eugene Gluzberg、Brian Goetz、Christoph Goller、Mark Harwook、Tim Jones、Daniel Naber、Andrew C. Oliver、Dmitry Serebrennikov、Kelvin Tan和Matt Tucher。
同时,我们感谢所有贡献在第10章的案例的人:Dion Almaer、Michael Cafarella、Bob Carpenter、Karsten Konrad、Terence Parr、Robert Selvaraj、Ralf Steinbach、Holger Stenzhorn和Craig Walls。
……本书简介Lucene in Action为使用最好的Java开源搜索引擎的用户提供所有细节、最好的实践、警告、技巧。
本书假设读者熟悉基本的Java编程。
Lucene本身是个Java档案(JAR)文件并能集成到简单的命令行程序和大型企业级应用程序中。
Roadmap我们在本书第1部分覆盖Lucene核心编程接口(API)使你在将Lucene整合到你的程序中时愿意使用它:n 第1章,接触Lucene。
我们介绍了一些基本的信息搜索术语和Lucene的主要竞争对手。
我们很快地构建了一个你马上能用或修改以适应需要的简单索引和搜索程序。
这个示例程序向你打开了探索Lucene其它能力的大门。
n 第2章使你熟悉Lucene基本的索引操作。
我们描述了索引数值和日期的不同字段类型和各种技术。
包括调整索引过程、优化索引以及如何处理线程安全。