Tools to work with vref files (e.g., in the ebible corpus)
Project description
Vref Utils
Tools to work with vref files
Report Bug
·
Request Feature
Getting Started
Installation
To install, use your favorite package manager and do the equivalent of:
pip install vref-utils
Usage
from vref_utils import Vref
niv = Vref("./en-NIV11.txt")
jhn3v16 = niv["JHN 3:16"][0]
print(jhn3v16)
# For God so loved the world that he gave his one and only Son, that whoever believes in him shall not perish but have eternal life.
Note that __get_item__
(the function called by niv["JHN 3:16"]
) returns a VerseList
. The VerseList
class allows us to iterate through the verses using a generator, but we can also access elements using indices or slices. Here, we use [0]
to get the first (and only) Verse
.
print(repr(jhn3v16))
# Verse(verse="JHN 3:16", text="For God so loved the world that he gave his one and only Son, that whoever believes in him shall not perish but have eternal life.")
The Verse
class supports the __str__
and __repr__
methods. So casting the first element to a string by printing it prints the text. You can also return the verse text using the .text
attribute. Likewise, you can get the verse reference using the .reference
attribute.
print(jhn3v16.text)
# For God so loved the world that he gave his one and only Son, that whoever believes in him shall not perish but have eternal life.
print(jhn3v16.reference)
# JHN 3:16
Printing the reference is not useful when there is only one verse, but you can select multiple verses using ranges like "JHN 3:16-JHN 3:17" or selections like "JHN 3:16,JHN 3:17" or a combination of both like "JHN 3:16,JHN 3:17-JHN 3:18".
print(niv["JHN 3:16-JHN 3:17,JHN 3:18"])
# VerseList([
# Verse(verse="JHN 3:16", text="For God so loved the world that he gave his one and only Son,..."),
# Verse(verse="JHN 3:17", text="For God did not send his Son into the world to condemn the wo..."),
# Verse(verse="JHN 3:18", text="Whoever believes in him is not condemned, but whoever does no...")
# ])
Note:
- Book names must be valid USFM book names.
- Chapter and verse numbers must be valid.
- Books and chapters must be specified in full for ranges/selections.
- ❌
JHN 1:1-2
- ❌
JHN 1:1-1:2
- ✅
JHN 1:1-JHN 1:2
- ❌
Custom Versification Formats
By default, the org
versification system is used (and packaged in vref-utils
). If you have vref files that use a different versification system, you can specify it when creating the Vref
object.
from vref_utils import Vref
niv = Vref("./en-NIV11.txt", "custom_vref.txt")
# or, with named arguments:
niv = Vref("./en-MYBIBLE.txt", versification_vref_path="custom_vref.txt")
Contributing
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement". Don't forget to give the project a star! Thanks again!
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/AmazingFeature
) - Commit your Changes (
git commit -m 'Add some AmazingFeature'
) - Push to the Branch (
git push origin feature/AmazingFeature
) - Open a Pull Request
License
Distributed under the MIT License. See LICENSE.md
for more information.
Project details
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
File details
Details for the file vref_utils-0.0.8.tar.gz
.
File metadata
- Download URL: vref_utils-0.0.8.tar.gz
- Upload date:
- Size: 101.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e3b3d225f316aec70e87ad99deb27a747f62bb0fc6709acf9b375c1759a2554c |
|
MD5 | 43c7fa97d76ec71f5fa18b37eca81c0a |
|
BLAKE2b-256 | b9ee7466c52ba79c9457feeceebb1db8cf23ea717ba567b48c1fae2287bb7e10 |
File details
Details for the file vref_utils-0.0.8-py3-none-any.whl
.
File metadata
- Download URL: vref_utils-0.0.8-py3-none-any.whl
- Upload date:
- Size: 96.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3548fa413f51796ea6eec4e2c5d19ff28127d23cc08df254978acfa10da48985 |
|
MD5 | 69fe355433fe558a6fe5df402cb482d7 |
|
BLAKE2b-256 | 800281e096e866df1f4b23eed7d3e1d156cf46dd64e86c153c51e3e77b84c036 |