mirror of
https://github.com/vinta/awesome-python.git
synced 2025-01-18 15:27:01 +00:00
Merge pull request #771 from hulk9914/patch-5
Update sort.py to make the list "alphabetically sorted"
This commit is contained in:
commit
6041c0b211
29
sort.py
29
sort.py
|
@ -12,7 +12,33 @@
|
|||
This could be extended by having nested blocks, sorting them recursively
|
||||
and flattening the end structure into a list of lines. Revision 2 maybe ^.^.
|
||||
"""
|
||||
def sort_blocks():
|
||||
# First, we load the current README into memory
|
||||
with open('README.md', 'r') as read_me_file:
|
||||
read_me = read_me_file.read()
|
||||
|
||||
# Separating the 'table of contents' from the contents (blocks)
|
||||
table_of_contents = ''.join(read_me.split('- - -')[0])
|
||||
blocks = ''.join(read_me.split('- - -')[1]).split('\n# ')
|
||||
for i in range(len(blocks)):
|
||||
if i == 0:
|
||||
blocks[i] = blocks[i]+'\n'
|
||||
else:
|
||||
blocks[i] = '#' + blocks[i]+'\n'
|
||||
|
||||
# Sorting the libraries
|
||||
inner_blocks = sorted(blocks[0].split('##'))
|
||||
for i in range(1 , len(inner_blocks)):
|
||||
if inner_blocks[i][0] != '#':
|
||||
inner_blocks[i]='##'+inner_blocks[i]
|
||||
inner_blocks=''.join(inner_blocks)
|
||||
|
||||
# Replacing the non-sorted libraries by the sorted ones and gathering all at the final_README file
|
||||
blocks[0] = inner_blocks
|
||||
final_README = table_of_contents + '- - -'+ ''.join(blocks)
|
||||
|
||||
with open('README.md', 'w+') as sorted_file:
|
||||
sorted_file.write(final_README)
|
||||
|
||||
def main():
|
||||
# First, we load the current README into memory as an array of lines
|
||||
|
@ -45,6 +71,9 @@ def main():
|
|||
# And the result is written back to README.md
|
||||
sorted_file.write(''.join(blocks))
|
||||
|
||||
# Then we call the sorting method
|
||||
sort_blocks()
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
|
Loading…
Reference in New Issue
Block a user