I want it to produce the number next to a word so that I can ask the user to select the word by using the corresponding number.
This is my code
alt_words = hlst
loopnum = 8
for i in range(loopnum):
if i < len(alt_words):
print('{0}. {1:<20}'.format((i+1), alt_words[i]), end =' ')
if i == 0:
print('', end=' ')
if i + 9 <= len(alt_words):
print('{0}. {1:<20}'.format((i+9), alt_words[i+8]), end =' ')
if i + 17 <= len(alt_words):
print('{0}. {1:<20}'.format((i+17), alt_words[i+16]), end=' ')
print('\n'+'-'*80)
It produces this
The first number of each line gets printed on the left, but the word on the right, while the rest of the numbers and words get printed RTL. It seems that once python has started printing on a line LTR it can switch to RTL, but not back from RTL to LTR. Note how even the periods are printed to the right of the number for the second set of numbers on each line.
It works perfectly well and looks nice with english words:
I am guessing a work around might involve putting the number after the word, but I figure there must be a better way.
We maintain a flag to see if current row should be printed from left to right or right to left. We toggle the flag after every iteration. This article is contributed by DANISH_RAZA.
There is no such thing. printf does NOT execute from left to right, neither does it execute from right to left. It executes in the order of whatever the compiler likes, by its mood. It can even execute in a random order, if the compiler hates you.
For example, if you left-align text with content in the left-to-right (LTR) context, right-align the text to match the content’s mirrored position in the RTL context. Align a paragraph based on its language, not on the current context.
Arabic, Hebrew, Pashto, Urdu, and Sindhi are the most widespread RTL writing systems in modern times. Right-to-left can also refer to top-to-bottom, right-to-left (TB-RL or TBRL) scripts such as Chinese, Japanese, and Korean, though in modern times they are also commonly written left to right.
Put a Right-to-Left Embedding character, u'\u202B'
, at the beginning of each Hebrew word, and a Pop Directional Formatting character, u'\u202C'
, at the end of each word.
This will set the Hebrew words apart as RTL sections in an otherwise LTR document.
(Note that while this will produce the correct output, you're also dependent on the terminal application in which you're running this script having implemented the Unicode Bidirectional Algorithm correctly.)
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With