-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
14 changed files
with
393 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
import re | ||
|
||
from app.utils.parse_for_html import format_header | ||
from ..base_check import BasePresCriterion, answer | ||
|
||
|
||
class PresEmptySlideCheck(BasePresCriterion): | ||
description = "Проверка наличия пустых слайдов в презентации" | ||
id = 'pres_empty_slide' | ||
|
||
def __init__(self, file_info, status=False): | ||
super().__init__(file_info) | ||
self.status = status | ||
|
||
def check(self): | ||
result_str = '' | ||
page_titles = {} | ||
full_pages = {} | ||
empty_pages = [] | ||
pages_with_title = [] | ||
|
||
pages_with_images = [page for page, slide in enumerate(self.file.slides, 1) | ||
if slide.get_images() or slide.get_table()] | ||
|
||
for page, slide in enumerate(self.file.get_text_from_slides(), 1): | ||
slide_string = ''.join(slide.replace("\n", " ")) | ||
slide_without_page = re.sub(r'\d+(?=\s*$)', '', slide_string) | ||
full_pages[str(page)] = ''.join(char for char in slide_without_page.strip() if char.isprintable()) | ||
if not full_pages[str(page)]: | ||
empty_pages.append(page) | ||
|
||
for page, slide in enumerate(self.file.get_titles(), 1): | ||
page_titles[str(page)] = slide | ||
if slide != "Запасные слайды": | ||
if slide == full_pages[str(page)] and page not in pages_with_images and page not in empty_pages: | ||
pages_with_title.append(page) | ||
|
||
if self.file.presentation_name.endswith('.ppt') or self.file.presentation_name.endswith('.pptx'): | ||
|
||
if empty_pages and not pages_with_title: | ||
result_str += format_header( | ||
'Не пройдена! Обнаружены пустые слайды: {}'.format( | ||
', '.join(self.format_page_link(empty_pages))) | ||
) | ||
if pages_with_title and not empty_pages: | ||
result_str += format_header( | ||
'Не пройдена! Обнаружены слайды, в которых присутствует только заголовок: {}'.format( | ||
', '.join(self.format_page_link(pages_with_title))) | ||
) | ||
if empty_pages and pages_with_title: | ||
result_str += format_header( | ||
'Не пройдена! Обнаружены пустые слайды: {}, также обнаружены слайды, в которых присутствует только заголовок: {}'.format( | ||
', '.join(self.format_page_link(empty_pages)), ', '.join(self.format_page_link(pages_with_title))) | ||
) | ||
elif self.file.presentation_name.lower().endswith('.odp'): | ||
if empty_pages: | ||
result_str += format_header( | ||
'Не пройдена! Обнаружены пустые слайды или слайды, в которых присутствует только заголовок: {}'.format( | ||
', '.join(self.format_page_link(empty_pages))) | ||
) | ||
|
||
if not result_str: | ||
self.status = True | ||
result_str = 'Пройдена!' | ||
|
||
return answer(self.status, result_str) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from .md_uploader import MdUpload |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
import argparse | ||
|
||
from .md_uploader import main as md_uploader_main | ||
|
||
|
||
def parse_args(): | ||
parser = argparse.ArgumentParser(description='File md parser') | ||
subparsers = parser.add_subparsers() | ||
md_parser = subparsers.add_parser('md_parser', help='md document') | ||
md_parser.add_argument('--mdfile', type=str, required=True, help='path to md file') | ||
md_parser.set_defaults(func=md_uploader_main) | ||
return parser.parse_args() | ||
|
||
|
||
def main(): | ||
args = parse_args() | ||
args.func(args) | ||
|
||
|
||
if __name__ == '__main__': | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
import markdown #installation: pip install markdown | ||
import re | ||
|
||
class MdUpload: | ||
def __init__(self, path_to_md_file): | ||
self.path_to_md_file = path_to_md_file | ||
self.headers = [] | ||
self.chapters = [] | ||
self.paragraphs = [] | ||
self.html_text = '' | ||
self.tables = [] | ||
self.chapter_with_text = [] | ||
|
||
def read_md_file(self): | ||
with open(self.path_to_md_file, "r", encoding="utf-8") as f: | ||
md_text = f.read() | ||
return md_text | ||
|
||
def get_html_from_md(self, md_text): | ||
self.html_text = markdown.markdown(md_text) | ||
self.paragraphs = self.html_text.split('\n') | ||
|
||
def get_headers(self): | ||
header_regex = "<h1>(.*?)<\/h1>" | ||
self.headers = re.findall(header_regex, self.html_text) | ||
|
||
def get_chapters(self): | ||
chapter_regex = "<h2>(.*?)<\/h2>" | ||
self.chapters = re.findall(chapter_regex, self.html_text) | ||
|
||
def get_chapter_with_text(self): | ||
text = self.html_text | ||
chapter_name = '' | ||
for chapter in self.chapters: | ||
self.split_chapter = text.split("<h2>" + chapter + "</h2>") | ||
self.chapter_with_text.append(chapter_name + self.split_chapter[-2]) | ||
chapter_name = chapter | ||
text = self.split_chapter[-1] | ||
self.chapter_with_text.append(chapter_name + text) | ||
|
||
def get_tables_size(self): | ||
count_table_line = 0 | ||
count_paragraph = len(self.paragraphs) | ||
for line in self.paragraphs: | ||
if "|" in line: | ||
count_table_line +=1 | ||
return round(count_table_line/count_paragraph, 4) | ||
|
||
def parse_md_file(self): | ||
md_text = self.read_md_file() | ||
self.get_html_from_md(md_text) | ||
self.get_headers() | ||
self.get_chapters() | ||
self.get_chapter_with_text() | ||
self.get_tables_size() | ||
return f"Заголовки:\n{self.headers}\n\nГлавы:\n{self.chapters}\n\nГлавы с текстом:\n{self.chapter_with_text}\n\nДоля таблиц в тексте:\n{self.get_tables_size()}" | ||
|
||
def main(args): | ||
md_file = MdUpload(args.mdfile) | ||
print(md_file.parse_md_file()) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.