1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- # -*- coding: utf-8 -*-
- from __future__ import absolute_import, unicode_literals
- import json
- def parse_line(line, category):
- name = line.split('](')[0][3:]
- url = line.split('](')[1].split(')')[0]
- description = '' if line[-1] == ')' else line.split(') ')[1][2:]
- return {
- 'name': name,
- 'description': description,
- 'url': url,
- 'category': category,
- }
- def parse_section(section, category=''):
- return [parse_line(l, category) for l in section.split('\n')]
- def parse_subsections(section):
- subsections = section.split('### ')[1:]
- items = []
- for subsection in subsections:
- split_section = subsection.split('\n\n')
- section_title = split_section[0]
- items += parse_section(split_section[1], section_title)
- return items
- def parse_apps(readme):
- section = readme.split('## Apps\n\n')[1].split('\n\n## Tools')[0]
- return parse_subsections(section)
- def parse_tools(readme):
- section = readme.split('## Tools\n\n')[1].split('\n\n## Resources')[0]
- return parse_section(section)
- def parse_resources(readme):
- section = readme.split('## Resources\n\n')[1].split('\n\n## Community')[0]
- return parse_subsections(section)
- def parse_sites(readme):
- section = readme.split('## Open-source sites\n\n')[1].split('\n\n## Contribute')[0]
- return parse_section(section)
- def parse_readme(readme):
- return {
- 'apps': parse_apps(readme),
- 'tools': parse_tools(readme),
- 'resources': parse_resources(readme),
- 'sites': parse_sites(readme),
- }
- if __name__ == '__main__':
- readme = open('README.md', 'r').read()
- readme_payload = parse_readme(readme)
- with open('./dist/api/v1/readme.json', mode='w+', encoding='utf-8') as f:
- f.write(json.dumps(readme_payload, indent=True))
|