Really simple django-app for search by Q-expressions
Project description
# django-silly-search
Simple django-app for search by Q-expressions.
[![Build Status](https://travis-ci.org/Egregors/django-silly-search.svg?branch=master)](https://travis-ci.org/Egregors/django-silly-search)
If you need the simple way to search, without full-text,
morphology features, this app may be useful. But, if you need search for more
complicated case, you should use something like [Haystack](http://haystacksearch.org/)
## Features
* Search for one or few models
* Search for multiple fields
## Install
Clone this repo and install from the source:
```
git clone https://github.com/Egregors/django-silly-search.git
cd django-silly-search
pip install -e .
```
or just use PyPI
```
pip install django-silly-search
```
## How to use
The app provides a single function:
```
from silly_search import q_search
# q_search(models, fields, q) -> list of ModelBase instances
```
The functions takes required arguments:
`models` – Models for search. Should be instance of `ModelBase` (regular Model)
or `list` of `ModelBase` instances
`fields` – Fields for search. Should be `str` or `list` of `str` (just name of models field)
`q` – phrase for search. Should be an `str`
As result, you'll get list of ModelBase instances.
Keep in mind, if you use it to search for few different models, you'll probably get
list of instances different ModelBase class heirs.
## Example
Let's say you have Models:
```
class Article(models.Model):
title = models.CharField(max_length=128)
description = models.CharField(max_length=255)
text = models.TextField()
class News(models.Model):
pub_date = models.DateTimeField(auto_now_add=True)
title = models.CharField(max_length=128)
text = models.TextField()Z
```
and you want to make search on these models. So, you can search for one model and one field:
```
q_search(Article, 'title', q='spam')
```
or for one models, but few fields:
```
q_search(Article, fields=['title', 'text'], q='spam')
```
or for few models and few fields:
```
q_search(models=[Article, News], fields=['title', 'description', 'text'], q='spam')
```
## Contributing
Bug reports, bug fixes, and new features are always welcome.
Please open issues, and submit pull requests for any new code.
Simple django-app for search by Q-expressions.
[![Build Status](https://travis-ci.org/Egregors/django-silly-search.svg?branch=master)](https://travis-ci.org/Egregors/django-silly-search)
If you need the simple way to search, without full-text,
morphology features, this app may be useful. But, if you need search for more
complicated case, you should use something like [Haystack](http://haystacksearch.org/)
## Features
* Search for one or few models
* Search for multiple fields
## Install
Clone this repo and install from the source:
```
git clone https://github.com/Egregors/django-silly-search.git
cd django-silly-search
pip install -e .
```
or just use PyPI
```
pip install django-silly-search
```
## How to use
The app provides a single function:
```
from silly_search import q_search
# q_search(models, fields, q) -> list of ModelBase instances
```
The functions takes required arguments:
`models` – Models for search. Should be instance of `ModelBase` (regular Model)
or `list` of `ModelBase` instances
`fields` – Fields for search. Should be `str` or `list` of `str` (just name of models field)
`q` – phrase for search. Should be an `str`
As result, you'll get list of ModelBase instances.
Keep in mind, if you use it to search for few different models, you'll probably get
list of instances different ModelBase class heirs.
## Example
Let's say you have Models:
```
class Article(models.Model):
title = models.CharField(max_length=128)
description = models.CharField(max_length=255)
text = models.TextField()
class News(models.Model):
pub_date = models.DateTimeField(auto_now_add=True)
title = models.CharField(max_length=128)
text = models.TextField()Z
```
and you want to make search on these models. So, you can search for one model and one field:
```
q_search(Article, 'title', q='spam')
```
or for one models, but few fields:
```
q_search(Article, fields=['title', 'text'], q='spam')
```
or for few models and few fields:
```
q_search(models=[Article, News], fields=['title', 'description', 'text'], q='spam')
```
## Contributing
Bug reports, bug fixes, and new features are always welcome.
Please open issues, and submit pull requests for any new code.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Close
Hashes for django-silly-search-0.1.2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 408ef136511152eecddfa5aa54657e2da2e2206c60d0448c699061bb0471fb71 |
|
MD5 | 88476374e8261068e34500bf7d742a93 |
|
BLAKE2b-256 | 701580d37a14b57e1ff0c795adfd2ea2efd756b4a884056c3c156dd979877589 |
Close
Hashes for django_silly_search-0.1.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 37b2388f8a1114520ead5d4cbc0973e060feb5ab07c19601afdfaed43e0fa685 |
|
MD5 | 993b1dc9845d31d9368273677fb9c640 |
|
BLAKE2b-256 | 431b6a882aa8b17375f5bf4678ae73fad371e2e54933faae3b60ad53cb2af3d1 |