From 2c59e7b0f7632b2dc4df15b50eb60dcf6b084945 Mon Sep 17 00:00:00 2001 From: Vinayak Mehta Date: Tue, 15 Jun 2021 03:29:35 +0530 Subject: [PATCH] Blacken code --- camelot/core.py | 22 +- camelot/ext/ghostscript/__init__.py | 3 +- camelot/handlers.py | 4 +- camelot/parsers/base.py | 3 +- camelot/parsers/stream.py | 10 +- camelot/plotting.py | 10 +- camelot/utils.py | 4 +- docs/_themes/flask_theme_support.py | 145 ++++---- docs/conf.py | 120 ++++--- setup.py | 101 +++--- tests/data.py | 508 +++++++++++++++++++++++++--- 11 files changed, 676 insertions(+), 254 deletions(-) diff --git a/camelot/core.py b/camelot/core.py index fdc2ae3..65fd1a6 100644 --- a/camelot/core.py +++ b/camelot/core.py @@ -55,7 +55,9 @@ class TextEdge(object): x = round(self.x, 2) y0 = round(self.y0, 2) y1 = round(self.y1, 2) - return f"" + return ( + f"" + ) def update_coords(self, x, y0, edge_tol=50): """Updates the text edge's x and bottom y coordinates and sets @@ -102,8 +104,7 @@ class TextEdges(object): return None def add(self, textline, align): - """Adds a new text edge to the current dict. - """ + """Adds a new text edge to the current dict.""" x = self.get_x_coord(textline, align) y0 = textline.y0 y1 = textline.y1 @@ -111,8 +112,7 @@ class TextEdges(object): self._textedges[align].append(te) def update(self, textline): - """Updates an existing text edge in the current dict. - """ + """Updates an existing text edge in the current dict.""" for align in ["left", "right", "middle"]: x_coord = self.get_x_coord(textline, align) idx = self.find(x_coord, align) @@ -304,8 +304,7 @@ class Cell(object): @property def bound(self): - """The number of sides on which the cell is bounded. - """ + """The number of sides on which the cell is bounded.""" return self.top + self.bottom + self.left + self.right @@ -361,8 +360,7 @@ class Table(object): @property def data(self): - """Returns two-dimensional list of strings in table. - """ + """Returns two-dimensional list of strings in table.""" d = [] for row in self.cells: d.append([cell.text.strip() for cell in row]) @@ -383,8 +381,7 @@ class Table(object): return report def set_all_edges(self): - """Sets all table edges to True. - """ + """Sets all table edges to True.""" for row in self.cells: for cell in row: cell.left = cell.right = cell.top = cell.bottom = True @@ -526,8 +523,7 @@ class Table(object): return self def set_border(self): - """Sets table border edges to True. - """ + """Sets table border edges to True.""" for r in range(len(self.rows)): self.cells[r][0].left = True self.cells[r][len(self.cols) - 1].right = True diff --git a/camelot/ext/ghostscript/__init__.py b/camelot/ext/ghostscript/__init__.py index 1b4ec48..5816475 100644 --- a/camelot/ext/ghostscript/__init__.py +++ b/camelot/ext/ghostscript/__init__.py @@ -81,8 +81,7 @@ class __Ghostscript(object): def Ghostscript(*args, **kwargs): - """Factory function for setting up a Ghostscript instance - """ + """Factory function for setting up a Ghostscript instance""" global __instance__ # Ghostscript only supports a single instance if __instance__ is None: diff --git a/camelot/handlers.py b/camelot/handlers.py index 9ec10bb..fb8d4b5 100644 --- a/camelot/handlers.py +++ b/camelot/handlers.py @@ -167,9 +167,7 @@ class PDFHandler(object): with TemporaryDirectory() as tempdir: for p in self.pages: self._save_page(self.filepath, p, tempdir) - pages = [ - os.path.join(tempdir, f"page-{p}.pdf") for p in self.pages - ] + pages = [os.path.join(tempdir, f"page-{p}.pdf") for p in self.pages] parser = Lattice(**kwargs) if flavor == "lattice" else Stream(**kwargs) for p in pages: t = parser.extract_tables( diff --git a/camelot/parsers/base.py b/camelot/parsers/base.py index cb1bc21..79be789 100644 --- a/camelot/parsers/base.py +++ b/camelot/parsers/base.py @@ -6,8 +6,7 @@ from ..utils import get_page_layout, get_text_objects class BaseParser(object): - """Defines a base parser. - """ + """Defines a base parser.""" def _generate_layout(self, filename, layout_kwargs): self.filename = filename diff --git a/camelot/parsers/stream.py b/camelot/parsers/stream.py index 39a0464..c7b21da 100644 --- a/camelot/parsers/stream.py +++ b/camelot/parsers/stream.py @@ -65,7 +65,7 @@ class Stream(BaseParser): edge_tol=50, row_tol=2, column_tol=0, - **kwargs + **kwargs, ): self.table_regions = table_regions self.table_areas = table_areas @@ -362,10 +362,10 @@ class Stream(BaseParser): if len(elements): ncols = max(set(elements), key=elements.count) else: - warnings.warn( - f"No tables found in table area {table_idx + 1}" - ) - cols = [(t.x0, t.x1) for r in rows_grouped if len(r) == ncols for t in r] + warnings.warn(f"No tables found in table area {table_idx + 1}") + cols = [ + (t.x0, t.x1) for r in rows_grouped if len(r) == ncols for t in r + ] cols = self._merge_columns(sorted(cols), column_tol=self.column_tol) inner_text = [] for i in range(1, len(cols)): diff --git a/camelot/plotting.py b/camelot/plotting.py index 473ad13..f5b6afe 100644 --- a/camelot/plotting.py +++ b/camelot/plotting.py @@ -34,13 +34,9 @@ class PlotMethods(object): raise ImportError("matplotlib is required for plotting.") if table.flavor == "lattice" and kind in ["textedge"]: - raise NotImplementedError( - f"Lattice flavor does not support kind='{kind}'" - ) + raise NotImplementedError(f"Lattice flavor does not support kind='{kind}'") elif table.flavor == "stream" and kind in ["joint", "line"]: - raise NotImplementedError( - f"Stream flavor does not support kind='{kind}'" - ) + raise NotImplementedError(f"Stream flavor does not support kind='{kind}'") plot_method = getattr(self, kind) fig = plot_method(table) @@ -48,7 +44,7 @@ class PlotMethods(object): if filename is not None: fig.savefig(filename) return None - + return fig def text(self, table): diff --git a/camelot/utils.py b/camelot/utils.py index 2126fbb..43e4312 100644 --- a/camelot/utils.py +++ b/camelot/utils.py @@ -870,7 +870,9 @@ def get_page_layout( parser = PDFParser(f) document = PDFDocument(parser) if not document.is_extractable: - raise PDFTextExtractionNotAllowed(f"Text extraction is not allowed: {filename}") + raise PDFTextExtractionNotAllowed( + f"Text extraction is not allowed: {filename}" + ) laparams = LAParams( char_margin=char_margin, line_margin=line_margin, diff --git a/docs/_themes/flask_theme_support.py b/docs/_themes/flask_theme_support.py index fde6274..90005c6 100644 --- a/docs/_themes/flask_theme_support.py +++ b/docs/_themes/flask_theme_support.py @@ -1,7 +1,19 @@ # flasky pygments style based on tango style from pygments.style import Style -from pygments.token import Keyword, Name, Comment, String, Error, \ - Number, Operator, Generic, Whitespace, Punctuation, Other, Literal +from pygments.token import ( + Keyword, + Name, + Comment, + String, + Error, + Number, + Operator, + Generic, + Whitespace, + Punctuation, + Other, + Literal, +) class FlaskyStyle(Style): @@ -11,76 +23,67 @@ class FlaskyStyle(Style): styles = { # No corresponding class for the following: # Text: "", # class: '' - Whitespace: "underline #f8f8f8", # class: 'w' - Error: "#a40000 border:#ef2929", # class: 'err' - Other: "#000000", # class 'x' - - Comment: "italic #8f5902", # class: 'c' - Comment.Preproc: "noitalic", # class: 'cp' - - Keyword: "bold #004461", # class: 'k' - Keyword.Constant: "bold #004461", # class: 'kc' - Keyword.Declaration: "bold #004461", # class: 'kd' - Keyword.Namespace: "bold #004461", # class: 'kn' - Keyword.Pseudo: "bold #004461", # class: 'kp' - Keyword.Reserved: "bold #004461", # class: 'kr' - Keyword.Type: "bold #004461", # class: 'kt' - - Operator: "#582800", # class: 'o' - Operator.Word: "bold #004461", # class: 'ow' - like keywords - - Punctuation: "bold #000000", # class: 'p' - + Whitespace: "underline #f8f8f8", # class: 'w' + Error: "#a40000 border:#ef2929", # class: 'err' + Other: "#000000", # class 'x' + Comment: "italic #8f5902", # class: 'c' + Comment.Preproc: "noitalic", # class: 'cp' + Keyword: "bold #004461", # class: 'k' + Keyword.Constant: "bold #004461", # class: 'kc' + Keyword.Declaration: "bold #004461", # class: 'kd' + Keyword.Namespace: "bold #004461", # class: 'kn' + Keyword.Pseudo: "bold #004461", # class: 'kp' + Keyword.Reserved: "bold #004461", # class: 'kr' + Keyword.Type: "bold #004461", # class: 'kt' + Operator: "#582800", # class: 'o' + Operator.Word: "bold #004461", # class: 'ow' - like keywords + Punctuation: "bold #000000", # class: 'p' # because special names such as Name.Class, Name.Function, etc. # are not recognized as such later in the parsing, we choose them # to look the same as ordinary variables. - Name: "#000000", # class: 'n' - Name.Attribute: "#c4a000", # class: 'na' - to be revised - Name.Builtin: "#004461", # class: 'nb' - Name.Builtin.Pseudo: "#3465a4", # class: 'bp' - Name.Class: "#000000", # class: 'nc' - to be revised - Name.Constant: "#000000", # class: 'no' - to be revised - Name.Decorator: "#888", # class: 'nd' - to be revised - Name.Entity: "#ce5c00", # class: 'ni' - Name.Exception: "bold #cc0000", # class: 'ne' - Name.Function: "#000000", # class: 'nf' - Name.Property: "#000000", # class: 'py' - Name.Label: "#f57900", # class: 'nl' - Name.Namespace: "#000000", # class: 'nn' - to be revised - Name.Other: "#000000", # class: 'nx' - Name.Tag: "bold #004461", # class: 'nt' - like a keyword - Name.Variable: "#000000", # class: 'nv' - to be revised - Name.Variable.Class: "#000000", # class: 'vc' - to be revised - Name.Variable.Global: "#000000", # class: 'vg' - to be revised - Name.Variable.Instance: "#000000", # class: 'vi' - to be revised - - Number: "#990000", # class: 'm' - - Literal: "#000000", # class: 'l' - Literal.Date: "#000000", # class: 'ld' - - String: "#4e9a06", # class: 's' - String.Backtick: "#4e9a06", # class: 'sb' - String.Char: "#4e9a06", # class: 'sc' - String.Doc: "italic #8f5902", # class: 'sd' - like a comment - String.Double: "#4e9a06", # class: 's2' - String.Escape: "#4e9a06", # class: 'se' - String.Heredoc: "#4e9a06", # class: 'sh' - String.Interpol: "#4e9a06", # class: 'si' - String.Other: "#4e9a06", # class: 'sx' - String.Regex: "#4e9a06", # class: 'sr' - String.Single: "#4e9a06", # class: 's1' - String.Symbol: "#4e9a06", # class: 'ss' - - Generic: "#000000", # class: 'g' - Generic.Deleted: "#a40000", # class: 'gd' - Generic.Emph: "italic #000000", # class: 'ge' - Generic.Error: "#ef2929", # class: 'gr' - Generic.Heading: "bold #000080", # class: 'gh' - Generic.Inserted: "#00A000", # class: 'gi' - Generic.Output: "#888", # class: 'go' - Generic.Prompt: "#745334", # class: 'gp' - Generic.Strong: "bold #000000", # class: 'gs' - Generic.Subheading: "bold #800080", # class: 'gu' - Generic.Traceback: "bold #a40000", # class: 'gt' + Name: "#000000", # class: 'n' + Name.Attribute: "#c4a000", # class: 'na' - to be revised + Name.Builtin: "#004461", # class: 'nb' + Name.Builtin.Pseudo: "#3465a4", # class: 'bp' + Name.Class: "#000000", # class: 'nc' - to be revised + Name.Constant: "#000000", # class: 'no' - to be revised + Name.Decorator: "#888", # class: 'nd' - to be revised + Name.Entity: "#ce5c00", # class: 'ni' + Name.Exception: "bold #cc0000", # class: 'ne' + Name.Function: "#000000", # class: 'nf' + Name.Property: "#000000", # class: 'py' + Name.Label: "#f57900", # class: 'nl' + Name.Namespace: "#000000", # class: 'nn' - to be revised + Name.Other: "#000000", # class: 'nx' + Name.Tag: "bold #004461", # class: 'nt' - like a keyword + Name.Variable: "#000000", # class: 'nv' - to be revised + Name.Variable.Class: "#000000", # class: 'vc' - to be revised + Name.Variable.Global: "#000000", # class: 'vg' - to be revised + Name.Variable.Instance: "#000000", # class: 'vi' - to be revised + Number: "#990000", # class: 'm' + Literal: "#000000", # class: 'l' + Literal.Date: "#000000", # class: 'ld' + String: "#4e9a06", # class: 's' + String.Backtick: "#4e9a06", # class: 'sb' + String.Char: "#4e9a06", # class: 'sc' + String.Doc: "italic #8f5902", # class: 'sd' - like a comment + String.Double: "#4e9a06", # class: 's2' + String.Escape: "#4e9a06", # class: 'se' + String.Heredoc: "#4e9a06", # class: 'sh' + String.Interpol: "#4e9a06", # class: 'si' + String.Other: "#4e9a06", # class: 'sx' + String.Regex: "#4e9a06", # class: 'sr' + String.Single: "#4e9a06", # class: 's1' + String.Symbol: "#4e9a06", # class: 'ss' + Generic: "#000000", # class: 'g' + Generic.Deleted: "#a40000", # class: 'gd' + Generic.Emph: "italic #000000", # class: 'ge' + Generic.Error: "#ef2929", # class: 'gr' + Generic.Heading: "bold #000080", # class: 'gh' + Generic.Inserted: "#00A000", # class: 'gi' + Generic.Output: "#888", # class: 'go' + Generic.Prompt: "#745334", # class: 'gp' + Generic.Strong: "bold #000000", # class: 'gs' + Generic.Subheading: "bold #800080", # class: 'gu' + Generic.Traceback: "bold #a40000", # class: 'gt' } diff --git a/docs/conf.py b/docs/conf.py index 018f393..7309ea5 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -22,8 +22,8 @@ import sys # sys.path.insert(0, os.path.abspath('..')) # Insert Camelot's path into the system. -sys.path.insert(0, os.path.abspath('..')) -sys.path.insert(0, os.path.abspath('_themes')) +sys.path.insert(0, os.path.abspath("..")) +sys.path.insert(0, os.path.abspath("_themes")) import camelot @@ -38,33 +38,33 @@ import camelot # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom # ones. extensions = [ - 'sphinx.ext.autodoc', - 'sphinx.ext.napoleon', - 'sphinx.ext.intersphinx', - 'sphinx.ext.todo', - 'sphinx.ext.viewcode', + "sphinx.ext.autodoc", + "sphinx.ext.napoleon", + "sphinx.ext.intersphinx", + "sphinx.ext.todo", + "sphinx.ext.viewcode", ] # Add any paths that contain templates here, relative to this directory. -templates_path = ['_templates'] +templates_path = ["_templates"] # The suffix(es) of source filenames. # You can specify multiple suffix as a list of string: # # source_suffix = ['.rst', '.md'] -source_suffix = '.rst' +source_suffix = ".rst" # The encoding of source files. # # source_encoding = 'utf-8-sig' # The master toctree document. -master_doc = 'index' +master_doc = "index" # General information about the project. -project = u'Camelot' -copyright = u'2020, Camelot Developers' -author = u'Vinayak Mehta' +project = u"Camelot" +copyright = u"2020, Camelot Developers" +author = u"Vinayak Mehta" # The version info for the project you're documenting, acts as replacement for # |version| and |release|, also used in various other places throughout the @@ -94,7 +94,7 @@ language = None # List of patterns, relative to source directory, that match files and # directories to ignore when looking for source files. # This patterns also effect to html_static_path and html_extra_path -exclude_patterns = ['_build'] +exclude_patterns = ["_build"] # The reST default role (used for this markup: `text`) to use for all # documents. @@ -114,7 +114,7 @@ add_module_names = True # show_authors = False # The name of the Pygments (syntax highlighting) style to use. -pygments_style = 'flask_theme_support.FlaskyStyle' +pygments_style = "flask_theme_support.FlaskyStyle" # A list of ignored prefixes for module index sorting. # modindex_common_prefix = [] @@ -130,18 +130,18 @@ todo_include_todos = True # The theme to use for HTML and HTML Help pages. See the documentation for # a list of builtin themes. -html_theme = 'alabaster' +html_theme = "alabaster" # Theme options are theme-specific and customize the look and feel of a theme # further. For a list of options available for each theme, see the # documentation. html_theme_options = { - 'show_powered_by': False, - 'github_user': 'camelot-dev', - 'github_repo': 'camelot', - 'github_banner': True, - 'show_related': False, - 'note_bg': '#FFF59C' + "show_powered_by": False, + "github_user": "camelot-dev", + "github_repo": "camelot", + "github_banner": True, + "show_related": False, + "note_bg": "#FFF59C", } # Add any paths that contain custom themes here, relative to this directory. @@ -164,12 +164,12 @@ html_theme_options = { # The name of an image file (relative to this directory) to use as a favicon of # the docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32 # pixels large. -html_favicon = '_static/favicon.ico' +html_favicon = "_static/favicon.ico" # Add any paths that contain custom static files (such as style sheets) here, # relative to this directory. They are copied after the builtin static files, # so a file named "default.css" will overwrite the builtin "default.css". -html_static_path = ['_static'] +html_static_path = ["_static"] # Add any extra paths that contain custom files (such as robots.txt or # .htaccess) here, relative to this directory. These files are copied @@ -189,10 +189,21 @@ html_use_smartypants = True # Custom sidebar templates, maps document names to template names. html_sidebars = { - 'index': ['sidebarintro.html', 'relations.html', 'sourcelink.html', - 'searchbox.html', 'hacks.html'], - '**': ['sidebarlogo.html', 'localtoc.html', 'relations.html', - 'sourcelink.html', 'searchbox.html', 'hacks.html'] + "index": [ + "sidebarintro.html", + "relations.html", + "sourcelink.html", + "searchbox.html", + "hacks.html", + ], + "**": [ + "sidebarlogo.html", + "localtoc.html", + "relations.html", + "sourcelink.html", + "searchbox.html", + "hacks.html", + ], } # Additional templates that should be rendered to pages, maps page names to @@ -249,34 +260,30 @@ html_show_copyright = True # html_search_scorer = 'scorer.js' # Output file base name for HTML help builder. -htmlhelp_basename = 'Camelotdoc' +htmlhelp_basename = "Camelotdoc" # -- Options for LaTeX output --------------------------------------------- latex_elements = { - # The paper size ('letterpaper' or 'a4paper'). - # - # 'papersize': 'letterpaper', - - # The font size ('10pt', '11pt' or '12pt'). - # - # 'pointsize': '10pt', - - # Additional stuff for the LaTeX preamble. - # - # 'preamble': '', - - # Latex figure (float) alignment - # - # 'figure_align': 'htbp', + # The paper size ('letterpaper' or 'a4paper'). + # + # 'papersize': 'letterpaper', + # The font size ('10pt', '11pt' or '12pt'). + # + # 'pointsize': '10pt', + # Additional stuff for the LaTeX preamble. + # + # 'preamble': '', + # Latex figure (float) alignment + # + # 'figure_align': 'htbp', } # Grouping the document tree into LaTeX files. List of tuples # (source start file, target name, title, # author, documentclass [howto, manual, or own class]). latex_documents = [ - (master_doc, 'Camelot.tex', u'Camelot Documentation', - u'Vinayak Mehta', 'manual'), + (master_doc, "Camelot.tex", u"Camelot Documentation", u"Vinayak Mehta", "manual"), ] # The name of an image file (relative to this directory) to place at the top of @@ -316,10 +323,7 @@ latex_documents = [ # One entry per manual page. List of tuples # (source start file, name, description, authors, manual section). -man_pages = [ - (master_doc, 'Camelot', u'Camelot Documentation', - [author], 1) -] +man_pages = [(master_doc, "Camelot", u"Camelot Documentation", [author], 1)] # If true, show URL addresses after external links. # @@ -332,9 +336,15 @@ man_pages = [ # (source start file, target name, title, author, # dir menu entry, description, category) texinfo_documents = [ - (master_doc, 'Camelot', u'Camelot Documentation', - author, 'Camelot', 'One line description of project.', - 'Miscellaneous'), + ( + master_doc, + "Camelot", + u"Camelot Documentation", + author, + "Camelot", + "One line description of project.", + "Miscellaneous", + ), ] # Documents to append as an appendix to all manuals. @@ -356,6 +366,6 @@ texinfo_documents = [ # Example configuration for intersphinx: refer to the Python standard library. intersphinx_mapping = { - 'https://docs.python.org/2': None, - 'http://pandas.pydata.org/pandas-docs/stable': None + "https://docs.python.org/2": None, + "http://pandas.pydata.org/pandas-docs/stable": None, } diff --git a/setup.py b/setup.py index b1ac666..c3a68d1 100644 --- a/setup.py +++ b/setup.py @@ -6,38 +6,36 @@ from setuptools import find_packages here = os.path.abspath(os.path.dirname(__file__)) about = {} -with open(os.path.join(here, 'camelot', '__version__.py'), 'r') as f: +with open(os.path.join(here, "camelot", "__version__.py"), "r") as f: exec(f.read(), about) -with open('README.md', 'r') as f: +with open("README.md", "r") as f: readme = f.read() requires = [ - 'chardet>=3.0.4', - 'click>=6.7', - 'numpy>=1.13.3', - 'openpyxl>=2.5.8', - 'pandas>=0.23.4', - 'pdfminer.six>=20200726', - 'PyPDF2>=1.26.0' + "chardet>=3.0.4", + "click>=6.7", + "numpy>=1.13.3", + "openpyxl>=2.5.8", + "pandas>=0.23.4", + "pdfminer.six>=20200726", + "PyPDF2>=1.26.0", ] -cv_requires = [ - 'opencv-python>=3.4.2.17' -] +cv_requires = ["opencv-python>=3.4.2.17"] plot_requires = [ - 'matplotlib>=2.2.3', + "matplotlib>=2.2.3", ] dev_requires = [ - 'codecov>=2.0.15', - 'pytest>=5.4.3', - 'pytest-cov>=2.10.0', - 'pytest-mpl>=0.11', - 'pytest-runner>=5.2', - 'Sphinx>=3.1.2' + "codecov>=2.0.15", + "pytest>=5.4.3", + "pytest-cov>=2.10.0", + "pytest-mpl>=0.11", + "pytest-runner>=5.2", + "Sphinx>=3.1.2", ] all_requires = cv_requires + plot_requires @@ -45,36 +43,39 @@ dev_requires = dev_requires + all_requires def setup_package(): - metadata = dict(name=about['__title__'], - version=about['__version__'], - description=about['__description__'], - long_description=readme, - long_description_content_type="text/markdown", - url=about['__url__'], - author=about['__author__'], - author_email=about['__author_email__'], - license=about['__license__'], - packages=find_packages(exclude=('tests',)), - install_requires=requires, - extras_require={ - 'all': all_requires, - 'cv': cv_requires, - 'dev': dev_requires, - 'plot': plot_requires - }, - entry_points={ - 'console_scripts': [ - 'camelot = camelot.cli:cli', - ], - }, - classifiers=[ - # Trove classifiers - # Full list: https://pypi.python.org/pypi?%3Aaction=list_classifiers - 'License :: OSI Approved :: MIT License', - 'Programming Language :: Python :: 3.6', - 'Programming Language :: Python :: 3.7', - 'Programming Language :: Python :: 3.8' - ]) + metadata = dict( + name=about["__title__"], + version=about["__version__"], + description=about["__description__"], + long_description=readme, + long_description_content_type="text/markdown", + url=about["__url__"], + author=about["__author__"], + author_email=about["__author_email__"], + license=about["__license__"], + packages=find_packages(exclude=("tests",)), + install_requires=requires, + extras_require={ + "all": all_requires, + "cv": cv_requires, + "dev": dev_requires, + "plot": plot_requires, + }, + entry_points={ + "console_scripts": [ + "camelot = camelot.cli:cli", + ], + }, + classifiers=[ + # Trove classifiers + # Full list: https://pypi.python.org/pypi?%3Aaction=list_classifiers + "License :: OSI Approved :: MIT License", + "Programming Language :: Python :: 3.6", + "Programming Language :: Python :: 3.7", + "Programming Language :: Python :: 3.8", + "Programming Language :: Python :: 3.9", + ], + ) try: from setuptools import setup @@ -84,5 +85,5 @@ def setup_package(): setup(**metadata) -if __name__ == '__main__': +if __name__ == "__main__": setup_package() diff --git a/tests/data.py b/tests/data.py index b2bf706..835fbb4 100755 --- a/tests/data.py +++ b/tests/data.py @@ -2800,49 +2800,467 @@ data_stream_layout_kwargs = [ ] data_stream_duplicated_text = [ - ['', '2012 BETTER VARIETIES Harvest Report for Minnesota Central [ MNCE ]', '', '', '', '', '', '', '', '', - 'ALL SEASON TEST'], - ['', 'Doug Toreen, Renville County, MN 55310 [ BIRD ISLAND ]', '', '', '', '', '', '', '', '', - '1.3 - 2.0 MAT. GROUP'], - ['PREV. CROP/HERB:', 'Corn / Surpass, Roundup', '', '', '', '', '', '', '', '', 'S2MNCE01'], - ['SOIL DESCRIPTION:', '', 'Canisteo clay loam, mod. well drained, non-irrigated', '', '', '', '', '', '', '', ''], - ['SOIL CONDITIONS:', '', 'High P, high K, 6.7 pH, 3.9% OM, Low SCN', '', '', '', '', '', '', '', '30" ROW SPACING'], - ['TILLAGE/CULTIVATION:', 'conventional w/ fall till', '', '', '', '', '', '', '', '', ''], - ['PEST MANAGEMENT:', 'Roundup twice', '', '', '', '', '', '', '', '', ''], - ['SEEDED - RATE:', 'May 15', '140 000 /A', '', '', '', '', '', '', 'TOP 30 for YIELD of 63 TESTED', ''], - ['HARVESTED - STAND:', 'Oct 3', '122 921 /A', '', '', '', '', '', '', 'AVERAGE of (3) REPLICATIONS', ''], - ['', '', '', '', 'SCN', 'Seed', 'Yield', 'Moisture', 'Lodging', 'Stand', 'Gross'], - ['Company/Brand', 'Product/Brand†', 'Technol.†', 'Mat.', 'Resist.', 'Trmt.†', 'Bu/A', '%', '%', '(x 1000)', - 'Income'], ['Kruger', 'K2 1901', 'RR2Y', '1.9', 'R', 'Ac,PV', '56.4', '7.6', '0', '126.3', '$846'], - ['Stine', '19RA02 §', 'RR2Y', '1.9', 'R', 'CMB', '55.3', '7.6', '0', '120.0', '$830'], - ['Wensman', 'W 3190NR2', 'RR2Y', '1.9', 'R', 'Ac', '54.5', '7.6', '0', '119.5', '$818'], - ['Hefty', 'H17Y12', 'RR2Y', '1.7', 'MR', 'I', '53.7', '7.7', '0', '124.4', '$806'], - ['Dyna-Gro', 'S15RY53', 'RR2Y', '1.5', 'R', 'Ac', '53.6', '7.7', '0', '126.8', '$804'], - ['LG Seeds', 'C2050R2', 'RR2Y', '2.1', 'R', 'Ac', '53.6', '7.7', '0', '123.9', '$804'], - ['Titan Pro', '19M42', 'RR2Y', '1.9', 'R', 'CMB', '53.6', '7.7', '0', '121.0', '$804'], - ['Stine', '19RA02 (2) §', 'RR2Y', '1.9', 'R', 'CMB', '53.4', '7.7', '0', '123.9', '$801'], - ['Asgrow', 'AG1832 §', 'RR2Y', '1.8', 'MR', 'Ac,PV', '52.9', '7.7', '0', '122.0', '$794'], - ['Prairie Brand', 'PB-1566R2', 'RR2Y', '1.5', 'R', 'CMB', '52.8', '7.7', '0', '122.9', '$792'], - ['Channel', '1901R2', 'RR2Y', '1.9', 'R', 'Ac,PV', '52.8', '7.6', '0', '123.4', '$791'], - ['Titan Pro', '20M1', 'RR2Y', '2.0', 'R', 'Am', '52.5', '7.5', '0', '124.4', '$788'], - ['Kruger', 'K2-2002', 'RR2Y', '2.0', 'R', 'Ac,PV', '52.4', '7.9', '0', '125.4', '$786'], - ['Channel', '1700R2', 'RR2Y', '1.7', 'R', 'Ac,PV', '52.3', '7.9', '0', '123.9', '$784'], - ['Hefty', 'H16Y11', 'RR2Y', '1.6', 'MR', 'I', '51.4', '7.6', '0', '123.9', '$771'], - ['Anderson', '162R2Y', 'RR2Y', '1.6', 'R', 'None', '51.3', '7.5', '0', '119.5', '$770'], - ['Titan Pro', '15M22', 'RR2Y', '1.5', 'R', 'CMB', '51.3', '7.8', '0', '125.4', '$769'], - ['Dairyland', 'DSR-1710R2Y', 'RR2Y', '1.7', 'R', 'CMB', '51.3', '7.7', '0', '122.0', '$769'], - ['Hefty', 'H20R3', 'RR2Y', '2.0', 'MR', 'I', '50.5', '8.2', '0', '121.0', '$757'], - ['Prairie Brand', 'PB 1743R2', 'RR2Y', '1.7', 'R', 'CMB', '50.2', '7.7', '0', '125.8', '$752'], - ['Gold Country', '1741', 'RR2Y', '1.7', 'R', 'Ac', '50.1', '7.8', '0', '123.9', '$751'], - ['Trelay', '20RR43', 'RR2Y', '2.0', 'R', 'Ac,Ex', '49.9', '7.6', '0', '127.8', '$749'], - ['Hefty', 'H14R3', 'RR2Y', '1.4', 'MR', 'I', '49.7', '7.7', '0', '122.9', '$746'], - ['Prairie Brand', 'PB-2099NRR2', 'RR2Y', '2.0', 'R', 'CMB', '49.6', '7.8', '0', '126.3', '$743'], - ['Wensman', 'W 3174NR2', 'RR2Y', '1.7', 'R', 'Ac', '49.3', '7.6', '0', '122.5', '$740'], - ['Kruger', 'K2 1602', 'RR2Y', '1.6', 'R', 'Ac,PV', '48.7', '7.6', '0', '125.4', '$731'], - ['NK Brand', 'S18-C2 §', 'RR2Y', '1.8', 'R', 'CMB', '48.7', '7.7', '0', '126.8', '$731'], - ['Kruger', 'K2 1902', 'RR2Y', '1.9', 'R', 'Ac,PV', '48.7', '7.5', '0', '124.4', '$730'], - ['Prairie Brand', 'PB-1823R2', 'RR2Y', '1.8', 'R', 'None', '48.5', '7.6', '0', '121.0', '$727'], - ['Gold Country', '1541', 'RR2Y', '1.5', 'R', 'Ac', '48.4', '7.6', '0', '110.4', '$726'], - ['', '', '', '', '', 'Test Average =', '47.6', '7.7', '0', '122.9', '$713'], - ['', '', '', '', '', 'LSD (0.10) =', '5.7', '0.3', 'ns', '37.8', '566.4'] + [ + "", + "2012 BETTER VARIETIES Harvest Report for Minnesota Central [ MNCE ]", + "", + "", + "", + "", + "", + "", + "", + "", + "ALL SEASON TEST", + ], + [ + "", + "Doug Toreen, Renville County, MN 55310 [ BIRD ISLAND ]", + "", + "", + "", + "", + "", + "", + "", + "", + "1.3 - 2.0 MAT. GROUP", + ], + [ + "PREV. CROP/HERB:", + "Corn / Surpass, Roundup", + "", + "", + "", + "", + "", + "", + "", + "", + "S2MNCE01", + ], + [ + "SOIL DESCRIPTION:", + "", + "Canisteo clay loam, mod. well drained, non-irrigated", + "", + "", + "", + "", + "", + "", + "", + "", + ], + [ + "SOIL CONDITIONS:", + "", + "High P, high K, 6.7 pH, 3.9% OM, Low SCN", + "", + "", + "", + "", + "", + "", + "", + '30" ROW SPACING', + ], + [ + "TILLAGE/CULTIVATION:", + "conventional w/ fall till", + "", + "", + "", + "", + "", + "", + "", + "", + "", + ], + ["PEST MANAGEMENT:", "Roundup twice", "", "", "", "", "", "", "", "", ""], + [ + "SEEDED - RATE:", + "May 15", + "140 000 /A", + "", + "", + "", + "", + "", + "", + "TOP 30 for YIELD of 63 TESTED", + "", + ], + [ + "HARVESTED - STAND:", + "Oct 3", + "122 921 /A", + "", + "", + "", + "", + "", + "", + "AVERAGE of (3) REPLICATIONS", + "", + ], + ["", "", "", "", "SCN", "Seed", "Yield", "Moisture", "Lodging", "Stand", "Gross"], + [ + "Company/Brand", + "Product/Brand†", + "Technol.†", + "Mat.", + "Resist.", + "Trmt.†", + "Bu/A", + "%", + "%", + "(x 1000)", + "Income", + ], + [ + "Kruger", + "K2 1901", + "RR2Y", + "1.9", + "R", + "Ac,PV", + "56.4", + "7.6", + "0", + "126.3", + "$846", + ], + [ + "Stine", + "19RA02 §", + "RR2Y", + "1.9", + "R", + "CMB", + "55.3", + "7.6", + "0", + "120.0", + "$830", + ], + [ + "Wensman", + "W 3190NR2", + "RR2Y", + "1.9", + "R", + "Ac", + "54.5", + "7.6", + "0", + "119.5", + "$818", + ], + ["Hefty", "H17Y12", "RR2Y", "1.7", "MR", "I", "53.7", "7.7", "0", "124.4", "$806"], + [ + "Dyna-Gro", + "S15RY53", + "RR2Y", + "1.5", + "R", + "Ac", + "53.6", + "7.7", + "0", + "126.8", + "$804", + ], + [ + "LG Seeds", + "C2050R2", + "RR2Y", + "2.1", + "R", + "Ac", + "53.6", + "7.7", + "0", + "123.9", + "$804", + ], + [ + "Titan Pro", + "19M42", + "RR2Y", + "1.9", + "R", + "CMB", + "53.6", + "7.7", + "0", + "121.0", + "$804", + ], + [ + "Stine", + "19RA02 (2) §", + "RR2Y", + "1.9", + "R", + "CMB", + "53.4", + "7.7", + "0", + "123.9", + "$801", + ], + [ + "Asgrow", + "AG1832 §", + "RR2Y", + "1.8", + "MR", + "Ac,PV", + "52.9", + "7.7", + "0", + "122.0", + "$794", + ], + [ + "Prairie Brand", + "PB-1566R2", + "RR2Y", + "1.5", + "R", + "CMB", + "52.8", + "7.7", + "0", + "122.9", + "$792", + ], + [ + "Channel", + "1901R2", + "RR2Y", + "1.9", + "R", + "Ac,PV", + "52.8", + "7.6", + "0", + "123.4", + "$791", + ], + [ + "Titan Pro", + "20M1", + "RR2Y", + "2.0", + "R", + "Am", + "52.5", + "7.5", + "0", + "124.4", + "$788", + ], + [ + "Kruger", + "K2-2002", + "RR2Y", + "2.0", + "R", + "Ac,PV", + "52.4", + "7.9", + "0", + "125.4", + "$786", + ], + [ + "Channel", + "1700R2", + "RR2Y", + "1.7", + "R", + "Ac,PV", + "52.3", + "7.9", + "0", + "123.9", + "$784", + ], + ["Hefty", "H16Y11", "RR2Y", "1.6", "MR", "I", "51.4", "7.6", "0", "123.9", "$771"], + [ + "Anderson", + "162R2Y", + "RR2Y", + "1.6", + "R", + "None", + "51.3", + "7.5", + "0", + "119.5", + "$770", + ], + [ + "Titan Pro", + "15M22", + "RR2Y", + "1.5", + "R", + "CMB", + "51.3", + "7.8", + "0", + "125.4", + "$769", + ], + [ + "Dairyland", + "DSR-1710R2Y", + "RR2Y", + "1.7", + "R", + "CMB", + "51.3", + "7.7", + "0", + "122.0", + "$769", + ], + ["Hefty", "H20R3", "RR2Y", "2.0", "MR", "I", "50.5", "8.2", "0", "121.0", "$757"], + [ + "Prairie Brand", + "PB 1743R2", + "RR2Y", + "1.7", + "R", + "CMB", + "50.2", + "7.7", + "0", + "125.8", + "$752", + ], + [ + "Gold Country", + "1741", + "RR2Y", + "1.7", + "R", + "Ac", + "50.1", + "7.8", + "0", + "123.9", + "$751", + ], + [ + "Trelay", + "20RR43", + "RR2Y", + "2.0", + "R", + "Ac,Ex", + "49.9", + "7.6", + "0", + "127.8", + "$749", + ], + ["Hefty", "H14R3", "RR2Y", "1.4", "MR", "I", "49.7", "7.7", "0", "122.9", "$746"], + [ + "Prairie Brand", + "PB-2099NRR2", + "RR2Y", + "2.0", + "R", + "CMB", + "49.6", + "7.8", + "0", + "126.3", + "$743", + ], + [ + "Wensman", + "W 3174NR2", + "RR2Y", + "1.7", + "R", + "Ac", + "49.3", + "7.6", + "0", + "122.5", + "$740", + ], + [ + "Kruger", + "K2 1602", + "RR2Y", + "1.6", + "R", + "Ac,PV", + "48.7", + "7.6", + "0", + "125.4", + "$731", + ], + [ + "NK Brand", + "S18-C2 §", + "RR2Y", + "1.8", + "R", + "CMB", + "48.7", + "7.7", + "0", + "126.8", + "$731", + ], + [ + "Kruger", + "K2 1902", + "RR2Y", + "1.9", + "R", + "Ac,PV", + "48.7", + "7.5", + "0", + "124.4", + "$730", + ], + [ + "Prairie Brand", + "PB-1823R2", + "RR2Y", + "1.8", + "R", + "None", + "48.5", + "7.6", + "0", + "121.0", + "$727", + ], + [ + "Gold Country", + "1541", + "RR2Y", + "1.5", + "R", + "Ac", + "48.4", + "7.6", + "0", + "110.4", + "$726", + ], + ["", "", "", "", "", "Test Average =", "47.6", "7.7", "0", "122.9", "$713"], + ["", "", "", "", "", "LSD (0.10) =", "5.7", "0.3", "ns", "37.8", "566.4"], ]