rip-v3
v1.3.5
Published
Natural language parser for recipes and ingredient lists, incl. combining ingredients
Downloads
19
Maintainers
Readme
rip-v3
RECIPE INGREDIENT PARSER
Natural language parser for recipes and lists of ingredients. Can parse a string into an object and also combine an array of these ingredient objects.
About
This project was built on top of code written by nsafai. Forked from [suprmat95] (https://github.com/suprmat95/recipe-parser).
What's different from the original?
- added support for the French language (at work, comming soon).
- added support for the Italian language.
- added support for numbers written in words (for example
six cups milk
) - added support for preposition before name of ingredient (for example
six cups of milk
orsei tazze di latte
)
To install
npm install rip-v3
or yarn add rip-v3
To use
import { parse } from 'rip-v3';
And then use on a string, for example:
parse('1 teaspoon basil', 'eng');
or
parse('1 grammo di zucchero', 'ita');
Will return an object:
{
quantity: 1,
unit: 'teaspoon',
ingredient: 'basil',
minQty: 1,
maxQty: 1
};
Combine ingredient objects
combine([{
quantity: 1,
unit: 'teaspoon',
ingredient: 'basil',
minQty: 1,
maxQty: 2,
},
{
quantity: 2,
unit: 'teaspoon',
ingredient: 'basil',
minQty: 2,
maxQty: 2
}]);
Will return
[{
quantity: 3,
unit: 'teaspoon',
ingredient: 'basil',
minQty: 3,
maxQty: 4
}]
Languages supported
Languages currently supported:
- English
eng
- Italian
ita
- French
fre
Unicode Fractions
Will also correctly parse unicode fractions into the proper amount
Development
Clone the repo and yarn
to install packages. If yarn test
comes back good after your code changes, give yourself a pat on the back.
Natural Language Parsing
This project uses Natural, for more information, see https://dzone.com/articles/using-natural-nlp-module
Publishing
Checkout https://docs.npmjs.com/getting-started/publishing-npm-packages for more info