-
Notifications
You must be signed in to change notification settings - Fork 0
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
jim.molecule
committed
Mar 21, 2020
1 parent
a7b4e2a
commit 5b48ef9
Showing
25 changed files
with
821 additions
and
44 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
--- | ||
name: Bug report | ||
about: Create a report to help us improve | ||
title: '' | ||
labels: '' | ||
assignees: '' | ||
|
||
--- | ||
|
||
**Describe the bug** | ||
A clear and concise description of what the bug is. | ||
|
||
**To Reproduce** | ||
Steps to reproduce the behavior: | ||
1. Go to '...' | ||
2. Click on '....' | ||
3. Scroll down to '....' | ||
4. See error | ||
|
||
**Expected behavior** | ||
A clear and concise description of what you expected to happen. | ||
|
||
**Screenshots** | ||
If applicable, add screenshots to help explain your problem. | ||
|
||
**Desktop (please complete the following information):** | ||
- OS: [e.g. iOS] | ||
- Browser [e.g. chrome, safari] | ||
- Version [e.g. 22] | ||
|
||
**Smartphone (please complete the following information):** | ||
- Device: [e.g. iPhone6] | ||
- OS: [e.g. iOS8.1] | ||
- Browser [e.g. stock browser, safari] | ||
- Version [e.g. 22] | ||
|
||
**Additional context** | ||
Add any other context about the problem here. |
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,22 @@ | ||
--- | ||
name: Feature request | ||
about: Suggest an idea for this project | ||
title: '' | ||
labels: '' | ||
assignees: '' | ||
|
||
--- | ||
|
||
**Is your feature request related to a problem? Please describe.** | ||
A clear and concise description of what the problem is. Ex. | ||
I'm always frustrated when [...] | ||
|
||
**Describe the solution you'd like** | ||
A clear and concise description of what you want to happen. | ||
|
||
**Describe alternatives you've considered** | ||
A clear and concise description of any alternative solutions | ||
or features you've considered. | ||
|
||
**Additional context** | ||
Add any other context or screenshots about the feature request here. |
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
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
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 |
---|---|---|
@@ -1,37 +1,43 @@ | ||
## Welcome to GitHub Pages | ||
|
||
You can use the [editor on GitHub](https://github.com/jim-molecule/histogramer/edit/master/README.md) to maintain and preview the content for your website in Markdown files. | ||
|
||
Whenever you commit to this repository, GitHub Pages will run [Jekyll](https://jekyllrb.com/) to rebuild the pages in your site, from the content in your Markdown files. | ||
|
||
### Markdown | ||
|
||
Markdown is a lightweight and easy-to-use syntax for styling your writing. It includes conventions for | ||
|
||
```markdown | ||
Syntax highlighted code block | ||
|
||
# Header 1 | ||
## Header 2 | ||
### Header 3 | ||
|
||
- Bulleted | ||
- List | ||
|
||
1. Numbered | ||
2. List | ||
|
||
**Bold** and _Italic_ and `Code` text | ||
|
||
[Link](url) and data:image/s3,"s3://crabby-images/7c78b/7c78b21af0014bbf5fd05bb0b7d3bf9f19f96904" alt="Image" | ||
``` | ||
|
||
For more details see [GitHub Flavored Markdown](https://guides.github.com/features/mastering-markdown/). | ||
|
||
### Jekyll Themes | ||
|
||
Your Pages site will use the layout and styles from the Jekyll theme you have selected in your [repository settings](https://github.com/jim-molecule/histogramer/settings). The name of this theme is saved in the Jekyll `_config.yml` configuration file. | ||
|
||
### Support or Contact | ||
|
||
Having trouble with Pages? Check out our [documentation](https://help.github.com/categories/github-pages-basics/) or [contact support](https://github.com/contact) and we’ll help you sort it out. | ||
# Compatibility # | ||
Histogramer has tested using `python 3.6.8` virtual environment in: | ||
* Windows 10 OS | ||
* macOS Catalina | ||
|
||
# Description # | ||
This tool analyze text files in a directory (which was specified by user) | ||
and it's sub folders. Statistics by words count is gathering | ||
for each text file was found. Then a histogram will be building | ||
by this statistics. | ||
|
||
# Example # | ||
data:image/s3,"s3://crabby-images/ab24f/ab24f5439b2f46268d0bc162d4f7ce3ade0121da" alt="" | ||
|
||
# Installation # | ||
* #### Using a `*.whl` dist: #### | ||
* Download the latest `*.whl` version from a | ||
[releases page](https://github.com/jim-molecule/histogramer/releases) | ||
* Install histogramer: `pip3 install --upgrade path_to_wheel.whl` | ||
|
||
* #### Using sources: #### | ||
* Remove dist files from project root: | ||
* Windows: `RMDIR /Q/S build dist histogramer.egg-info` | ||
* Mac: `rm -r build dist histogramer.egg-info` | ||
* Install wheel: `pip3 install wheel` | ||
* Build dist: `python setup.py bdist_wheel` | ||
* Install histogramer: `pip3 install --upgrade path_to_wheel.whl` | ||
|
||
# Issues # | ||
Please, report about any issues to an | ||
[issues page](https://github.com/jim-molecule/histogramer/issues/new/choose) | ||
with `~/.logs` folder's files attached. | ||
|
||
# Testing # | ||
For run all tests, please, use `pytest ./histogramer/tests` from project root. | ||
Pytest options are placed in `~/histogramer/tests/pytest.ini` file. | ||
|
||
# Usage # | ||
Run a `python -m histogramer --help` script. | ||
|
||
# Virtual environment # | ||
For main usage `~/requirements_main.txt` should be installed. | ||
For testing: `~/requirements_tests.txt`. |
This file was deleted.
Oops, something went wrong.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
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,3 @@ | ||
""" | ||
Init for 'histogramer' python package. | ||
""" |
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,22 @@ | ||
""" | ||
Histogramer main module. | ||
""" | ||
import asyncio | ||
|
||
from histogramer.src.helpers.args_helper import parse_arguments | ||
from histogramer.src.helpers.log_helper import init_logger | ||
from histogramer.src.histogram import process_text_files, show_histogram | ||
|
||
|
||
async def main(): | ||
""" | ||
Run Histogrammer. | ||
:return: None. | ||
""" | ||
arguments = await parse_arguments() | ||
logger = await init_logger(folder_name=".logs", root_path=arguments.log) | ||
words_count = await process_text_files("*.txt", logger, arguments.path) | ||
await show_histogram(logger, words_count) | ||
|
||
|
||
{"__main__": lambda: asyncio.run(main())}.get(__name__, lambda: None)() |
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,3 @@ | ||
""" | ||
Init for 'histogramer' python package. | ||
""" |
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,3 @@ | ||
""" | ||
Init for 'helpers' python package. | ||
""" |
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,56 @@ | ||
""" | ||
Helps to work with argument parser. | ||
""" | ||
import argparse | ||
import os | ||
|
||
|
||
def __raise_error(path): | ||
""" | ||
Raise NotADirectoryError. | ||
:param path: Directory which should exists. | ||
:return: None. | ||
""" | ||
raise NotADirectoryError(f"directory '{path}' not exists") | ||
|
||
|
||
def get_dir_type(path): | ||
""" | ||
Validate that directory exists. | ||
:param path: Directory which should exists. | ||
:return: Path or NotADirectoryError if directory not exists. | ||
""" | ||
{False: lambda: __raise_error(path)}.get( | ||
os.path.isdir(path) or path == "0", lambda: None)() | ||
return path | ||
|
||
|
||
async def parse_arguments(raw_args=None): | ||
""" | ||
Parse arguments. | ||
:param raw_args: Arguments for arg parser. | ||
:return: Parsed arguments. | ||
""" | ||
parser = argparse.ArgumentParser(description="please, provide root path" | ||
" in which (and it's sub " | ||
"folders) text files " | ||
"will be processed for " | ||
"histogram building") | ||
parser.add_argument("-p", | ||
action="store", | ||
default="", | ||
dest="path", | ||
help="root path in which (and it's sub " | ||
"folders) text files will be processed", | ||
required=True, | ||
type=get_dir_type) | ||
parser.add_argument("-l", | ||
action="store", | ||
default=os.getcwd(), | ||
dest="log", | ||
help="path to store logs. Use '0' " | ||
"if you don't want to store them. " | ||
"Default value: ~/.logs/", | ||
required=False, | ||
type=get_dir_type) | ||
return parser.parse_args(raw_args) |
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,23 @@ | ||
""" | ||
Helps to work with datetime objects. | ||
""" | ||
from datetime import timedelta | ||
|
||
|
||
async def datetime_to_str(datetime_obj): | ||
""" | ||
Convert datetime object to formatted string. | ||
:param datetime_obj: Datetime object. | ||
:return: Formatted string. | ||
""" | ||
return datetime_obj.isoformat(sep=" ", timespec="milliseconds") | ||
|
||
|
||
async def get_duration(start, end): | ||
""" | ||
Get event duration. | ||
:param start: Datetime when an event started. | ||
:param end: Datetime when an event finished. | ||
:return: Time period as formatted string. | ||
""" | ||
return round(number=timedelta.total_seconds(end - start), ndigits=3) |
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,60 @@ | ||
""" | ||
Helps to work with console & file logger. | ||
""" | ||
import logging | ||
import os | ||
import shutil | ||
from logging.handlers import RotatingFileHandler | ||
from pathlib import Path | ||
|
||
|
||
def _add_rotating_file_handler(folder_name, logger, log_formatter, root_path): | ||
""" | ||
Add rotating file handler to the logger instance for logging to a file. | ||
:param folder_name: Name of the folder where logs will be stored. | ||
:param logger: Instance of logger. | ||
:param log_formatter: Format of log messages. | ||
:param root_path: Path to the log folder. | ||
:return: None. | ||
""" | ||
path = os.path.join(root_path, folder_name) | ||
file_name = os.path.join(path, ".histogramer") | ||
{True: lambda: shutil.rmtree(path, ignore_errors=True)}.get( | ||
os.path.isdir(file_name) | ||
and Path(file_name).stat().st_size >= 5 * (1024 ** 2), | ||
lambda: None)() | ||
# create folder for file logs if not exists | ||
Path(path).mkdir(parents=True, exist_ok=True) | ||
|
||
rotating_file_handler = RotatingFileHandler(filename=file_name) | ||
rotating_file_handler.setFormatter(fmt=log_formatter) | ||
rotating_file_handler.setLevel(level=logging.INFO) | ||
logger.addHandler(hdlr=rotating_file_handler) | ||
|
||
|
||
async def init_logger(folder_name, root_path): | ||
""" | ||
Configure logger for logging events in console (and in a file, optional). | ||
:param folder_name: Name of the folder where logs will be stored. | ||
:param root_path: Path to the log folder. | ||
:return: Instance of logger. | ||
""" | ||
log_formatter = logging.Formatter("[%(asctime)s] " | ||
"[%(threadName)s] " | ||
"[%(levelname)s] " | ||
"%(message)s") | ||
logger = logging.getLogger() | ||
logger.setLevel(level=logging.INFO) | ||
|
||
console_handler = logging.StreamHandler() | ||
console_handler.setFormatter(fmt=log_formatter) | ||
console_handler.setLevel(level=logging.ERROR) | ||
logger.addHandler(hdlr=console_handler) | ||
|
||
{"0": lambda: None}.get( | ||
root_path, | ||
lambda: _add_rotating_file_handler(folder_name, | ||
logger, | ||
log_formatter, | ||
root_path))() | ||
return logger |
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,16 @@ | ||
""" | ||
Helps to generate random objects. | ||
""" | ||
import secrets | ||
import string | ||
|
||
|
||
async def get_random_string(string_length=10): | ||
""" | ||
Generate a random string of fixed length. | ||
:param string_length: Length of string. | ||
:return: Random string of fixed length. | ||
""" | ||
|
||
return "".join(secrets.choice(string.ascii_lowercase) | ||
for _ in range(string_length)) |
Oops, something went wrong.