Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/blevesearch/bleve
A modern text/numeric/geo-spatial/vector indexing library for go
https://github.com/blevesearch/bleve
Last synced: 5 days ago
JSON representation
A modern text/numeric/geo-spatial/vector indexing library for go
- Host: GitHub
- URL: https://github.com/blevesearch/bleve
- Owner: blevesearch
- License: apache-2.0
- Created: 2014-04-17T21:02:18.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2024-04-12T17:14:23.000Z (9 months ago)
- Last Synced: 2024-04-14T05:11:44.217Z (9 months ago)
- Language: Go
- Homepage:
- Size: 15.5 MB
- Stars: 9,643
- Watchers: 241
- Forks: 666
- Open Issues: 305
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-go - bleve - Modern text indexing library for go. (Data Structures and Algorithms / Text Analysis)
- awesome-go-storage - bleve - A modern text indexing library for go. (Database Drivers)
- awesome-vector-database - bleve
- awesome-github-repos - blevesearch/bleve - A modern text/numeric/geo-spatial/vector indexing library for go (Go)
- awesome-list - bleve
- awesome-starts - blevesearch/bleve - A modern text indexing library for go (Go)
- go-awesome - bleve - modern text indexing (Open source library / Word Processing)
- awesome-go - bleve - Modern text indexing library for go. Stars:`10.2K`. (Data Structures and Algorithms / Text Analysis)
- awesome-go - bleve - Modern text indexing library for go. (Data Structures and Algorithms / Text Analysis)
- awesome-go - bleve - A modern text indexing library for go - ★ 4721 (Database Drivers)
- awesome-go-extra - bleve - 04-17T21:02:18Z|2022-08-24T06:33:40Z| (Generators / Text Analysis)
- awesome-go-storage - bleve - A modern text indexing library for go. (Database Drivers)
- awesome - bleve - A modern text indexing library for go (Go)
- awesome-starred - blevesearch/bleve - A modern text indexing library for go (others)
- my-awesome - blevesearch/bleve - 12 star:10.2k fork:0.7k A modern text/numeric/geo-spatial/vector indexing library for go (Go)
- awesome - blevesearch/bleve - A modern text/numeric/geo-spatial/vector indexing library for go (Go)
- awesome - blevesearch/bleve - A modern text/numeric/geo-spatial/vector indexing library for go (Go)
README
# ![bleve](docs/bleve.png) bleve
[![Tests](https://github.com/blevesearch/bleve/workflows/Tests/badge.svg?branch=master&event=push)](https://github.com/blevesearch/bleve/actions?query=workflow%3ATests+event%3Apush+branch%3Amaster)
[![Coverage Status](https://coveralls.io/repos/github/blevesearch/bleve/badge.svg?branch=master)](https://coveralls.io/github/blevesearch/bleve?branch=master)
[![GoDoc](https://godoc.org/github.com/blevesearch/bleve?status.svg)](https://godoc.org/github.com/blevesearch/bleve)
[![Join the chat at https://gitter.im/blevesearch/bleve](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/blevesearch/bleve?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[![codebeat](https://codebeat.co/badges/38a7cbc9-9cf5-41c0-a315-0746178230f4)](https://codebeat.co/projects/github-com-blevesearch-bleve)
[![Go Report Card](https://goreportcard.com/badge/blevesearch/bleve)](https://goreportcard.com/report/blevesearch/bleve)
[![Sourcegraph](https://sourcegraph.com/github.com/blevesearch/bleve/-/badge.svg)](https://sourcegraph.com/github.com/blevesearch/bleve?badge)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://opensource.org/licenses/Apache-2.0)A modern indexing + search library in GO
## Features
* Index any GO data structure or JSON
* Intelligent defaults backed up by powerful configuration ([scorch](https://github.com/blevesearch/bleve/blob/master/index/scorch/README.md))
* Supported field types:
* `text`, `number`, `datetime`, `boolean`, `geopoint`, `geoshape`, `IP`, `vector`
* Supported query types:
* `term`, `phrase`, `match`, `match_phrase`, `prefix`, `regexp`, `wildcard`, `fuzzy`
* term range, numeric range, date range, boolean field
* compound queries: `conjuncts`, `disjuncts`, boolean (`must`/`should`/`must_not`)
* [query string syntax](http://www.blevesearch.com/docs/Query-String-Query/)
* [geo spatial search](https://github.com/blevesearch/bleve/blob/master/geo/README.md)
* approximate k-nearest neighbors via [vector search](https://github.com/blevesearch/bleve/blob/master/docs/vectors.md)
* [tf-idf](https://en.wikipedia.org/wiki/Tf-idf) scoring
* Hybrid search: exact + semantic
* Query time boosting
* Search result match highlighting with document fragments
* Aggregations/faceting support:
* terms facet
* numeric range facet
* date range facet## Indexing
```go
message := struct{
Id string
From string
Body string
}{
Id: "example",
From: "[email protected]",
Body: "bleve indexing is easy",
}mapping := bleve.NewIndexMapping()
index, err := bleve.New("example.bleve", mapping)
if err != nil {
panic(err)
}
index.Index(message.Id, message)
```## Querying
```go
index, _ := bleve.Open("example.bleve")
query := bleve.NewQueryStringQuery("bleve")
searchRequest := bleve.NewSearchRequest(query)
searchResult, _ := index.Search(searchRequest)
```## Command Line Interface
To install the CLI for the latest release of bleve, run:
```bash
$ go install github.com/blevesearch/bleve/v2/cmd/bleve@latest
``````
$ bleve --help
Bleve is a command-line tool to interact with a bleve index.Usage:
bleve [command]Available Commands:
bulk bulk loads from newline delimited JSON files
check checks the contents of the index
count counts the number documents in the index
create creates a new index
dictionary prints the term dictionary for the specified field in the index
dump dumps the contents of the index
fields lists the fields in this index
help Help about any command
index adds the files to the index
mapping prints the mapping used for this index
query queries the index
registry registry lists the bleve components compiled into this executable
scorch command-line tool to interact with a scorch indexFlags:
-h, --help help for bleveUse "bleve [command] --help" for more information about a command.
```## Text Analysis
Bleve includes general-purpose analyzers (customizable) as well as pre-built text analyzers for the following languages:
Arabic (ar), Bulgarian (bg), Catalan (ca), Chinese-Japanese-Korean (cjk), Kurdish (ckb), Danish (da), German (de), Greek (el), English (en), Spanish - Castilian (es), Basque (eu), Persian (fa), Finnish (fi), French (fr), Gaelic (ga), Spanish - Galician (gl), Hindi (hi), Croatian (hr), Hungarian (hu), Armenian (hy), Indonesian (id, in), Italian (it), Dutch (nl), Norwegian (no), Polish (pl), Portuguese (pt), Romanian (ro), Russian (ru), Swedish (sv), Turkish (tr)
## Text Analysis Wizard
[bleveanalysis.couchbase.com](https://bleveanalysis.couchbase.com)
## Discussion/Issues
Discuss usage/development of bleve and/or report issues here:
* [Github issues](https://github.com/blevesearch/bleve/issues)
* [Google group](https://groups.google.com/forum/#!forum/bleve)## License
Apache License Version 2.0