#!/usr/bin/env python
# coding: utf-8
# # Print a specific verse (Nestle1904LFT)
# ## Table of content
# * 1 - Introduction
# * 2 - Load Text-Fabric app and data
# * 3 - Performing the queries
# * 3.1 - Show all object phrases in clauses
# * 3.2 - Selecting individual words of the verse
# * 3.3 - Available output formats
# # 1 - Introduction
# ##### [Back to TOC](#TOC)
#
# This Jupyter Notebook shows the method of selecting a specific verse from the Greek New Testament corpus for display or further processing.
# # 2 - Load Text-Fabric app and data
# ##### [Back to TOC](#TOC)
# In[1]:
get_ipython().run_line_magic('load_ext', 'autoreload')
get_ipython().run_line_magic('autoreload', '2')
# In[2]:
# Loading the Text-Fabric code
# Note: it is assumed Text-Fabric is installed in your environment
from tf.fabric import Fabric
from tf.app import use
# In[3]:
# load the N1904 app and data
N1904 = use ("tonyjurg/Nestle1904LFT", version="0.6", hoist=globals())
# In[4]:
# The following will push the Text-Fabric stylesheet to this notebook (to facilitate proper display with notebook viewer)
N1904.dh(N1904.getCss())
# In[5]:
# Set default view in a way to limit noise as much as possible.
N1904.displaySetup(condensed=True, multiFeatures=False,queryFeatures=False)
# # 3 - Performing the queries
# ##### [Back to TOC](#TOC)
# ## 3.1 - Show a specific verse
# ##### [Back to TOC](#TOC)
#
# The following example will query for a specific verte (i.e. Matthew 1:8). As expected, the query yealds one result.
# In[11]:
# Define the query template
VerseQuery = '''
book book=Mark
chapter chapter=1
verse verse=1
'''
# In[12]:
# The following will create a list containing ordered tuples consisting of node numbers of the items as they appear in the query
VerseResult = N1904.search(VerseQuery)
# In[9]:
# Print some of the results
# Note the options "condensed=True, multiFeatures=False,queryFeatures=False" are included below due to the earlier N1904.displaySetup(...)
N1904.show(VerseResult, start=1, end=2)
# ## 3.2 - Selecting individual words of the verse
# ##### [Back to TOC](#TOC)
# A similar (but still different) result can be obtained by selecting all words from the verse individualy. Since counting each word as separate result, the total figure for results is higher (in this case 15). Also note that the found items (i.e. individual words) are coloured yellow. The argument `"condensed=True"` combines all found items, limiting the display to just one instance of the verse (since all results are from the same verse). Would the argument `"condensed=False"` be suplied, the same verse would be printed 15 times, each time with the next consequent word coloured in yellow.
# In[14]:
# Define the query template
AltVerseQuery = '''
word book=Mark chapter=1 verse=1
'''
# The following will create a list containing ordered tuples consisting of node numbers of the items as they appear in the query
AltVerseResult = N1904.search(AltVerseQuery)
# Print some of the results
N1904.show(AltVerseResult, start=1, end=15, condensed=True, multiFeatures=False, withNodes=True)
# ## 3.3 - Available output formats
# ##### [Back to TOC](#TOC)
#
# To check the available formats to display the text:
# The same result (although formatted different) can be obtained by the following call:
# In[15]:
T.formats
# In[16]:
N1904.showFormats()
# In[17]:
T.text(139200,fmt='text-critical')
# In[18]:
T.text(139200,fmt='text-normalized')
# In[19]:
T.text(139200,fmt='text-orig-full')
# In[20]:
T.text(139200,fmt='text-unaccented')
# In[21]:
T.text(139200,fmt='text-transliterated')
# #### Remark regarding data
# Note that this data originates from file `otext.tf`:
#
# >
# ```
# @config
# ...
# @fmt:text-orig-full={word}{after}
# ...
# ```
#