269 lines
10 KiB
Scheme
269 lines
10 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
|
;;; Copyright © 2019 Pierre Langlois <pierre.langlois@gmx.com>
|
|
;;; Copyright © 2020 Tobias Geerinckx-Rice <me@tobias.gr>
|
|
;;; Copyright © 2020 Tanguy Le Carrour <tanguy@bioneland.org>
|
|
;;; Copyright © 2022 Guillaume Le Vaillant <glv@posteo.net>
|
|
;;;
|
|
;;; This file is part of GNU Guix.
|
|
;;;
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
|
;;; under the terms of the GNU General Public License as published by
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
;;; your option) any later version.
|
|
;;;
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;;; GNU General Public License for more details.
|
|
;;;
|
|
;;; You should have received a copy of the GNU General Public License
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
(define-module (gnu packages wireservice)
|
|
#:use-module ((guix licenses) #:prefix license:)
|
|
#:use-module (guix build-system python)
|
|
#:use-module (guix download)
|
|
#:use-module (guix git-download)
|
|
#:use-module (guix packages)
|
|
#:use-module (gnu packages)
|
|
#:use-module (gnu packages check)
|
|
#:use-module (gnu packages databases)
|
|
#:use-module (gnu packages python-web)
|
|
#:use-module (gnu packages python-xyz)
|
|
#:use-module (gnu packages sphinx)
|
|
#:use-module (gnu packages time)
|
|
#:use-module (gnu packages xml))
|
|
|
|
;; Common package definition for packages from https://github.com/wireservice.
|
|
(define-syntax-rule (wireservice-package extra-fields ...)
|
|
(package
|
|
(build-system python-build-system)
|
|
(arguments
|
|
`(#:phases
|
|
(modify-phases %standard-phases
|
|
(replace 'check
|
|
(lambda _
|
|
(invoke "nosetests" "tests")))
|
|
(add-after 'install 'install-docs
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
(doc (string-append out "/share/doc/"
|
|
,(package-name this-package)
|
|
"-"
|
|
,(package-version this-package))))
|
|
(with-directory-excursion "docs"
|
|
(for-each
|
|
(lambda (target)
|
|
(invoke "make" target)
|
|
(copy-recursively (string-append "_build/" target)
|
|
(string-append doc "/" target)))
|
|
'("html" "dirhtml" "singlehtml" "text")))
|
|
#t))))))
|
|
(license license:expat)
|
|
extra-fields ...))
|
|
|
|
(define-public python-leather
|
|
(wireservice-package
|
|
(name "python-leather")
|
|
(version "0.3.4")
|
|
(source (origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/wireservice/leather")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"00cg4cidl15q1xv2pmxdkia5brig7x0xy9hwf2mlf9cq39bpj1w6"))))
|
|
(native-inputs
|
|
`(("python-nose" ,python-nose)
|
|
("python-sphinx" ,python-sphinx)
|
|
("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)
|
|
("python-csselect" ,python-cssselect)
|
|
("python-lxml" ,python-lxml)))
|
|
(propagated-inputs
|
|
`(("python-six" ,python-six)))
|
|
(home-page "https://leather.rtfd.org")
|
|
(synopsis "Python charting for 80% of humans")
|
|
(description "Leather is a Python charting library for those who need
|
|
charts now and don't care if they're perfect.")))
|
|
|
|
(define-public python-agate
|
|
(wireservice-package
|
|
(name "python-agate")
|
|
(version "1.6.1")
|
|
(source (origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/wireservice/agate")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"077zj8xad8hsa3nqywvf7ircirmx3krxdipl8wr3dynv3l3khcpl"))))
|
|
(native-inputs
|
|
`(("python-nose" ,python-nose)
|
|
("python-sphinx" ,python-sphinx)
|
|
("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)
|
|
("python-csselect" ,python-cssselect)
|
|
("python-lxml" ,python-lxml)))
|
|
(propagated-inputs
|
|
`(("python-babel" ,python-babel)
|
|
("python-isodate" ,python-isodate)
|
|
("python-leather" ,python-leather)
|
|
("python-parsedatetime" ,python-parsedatetime)
|
|
("python-pytimeparse" ,python-pytimeparse)
|
|
("python-six" ,python-six)
|
|
("python-slugify" ,python-slugify)))
|
|
(home-page "https://agate.rtfd.org")
|
|
(synopsis "Data analysis library")
|
|
(description "Agate is a Python data analysis library. It is an
|
|
alternative to numpy and pandas that solves real-world problems with readable
|
|
code. Agate was previously known as journalism.")))
|
|
|
|
(define-public python-agate-sql
|
|
(wireservice-package
|
|
(name "python-agate-sql")
|
|
(version "0.5.7")
|
|
(source (origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/wireservice/agate-sql")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"1q6ywm0wzkkwcwk0884k0lycf8k7pzwz94rzb1y5ssm8b1gl0i62"))))
|
|
(native-inputs
|
|
`(("python-nose" ,python-nose)
|
|
("python-sphinx" ,python-sphinx)
|
|
("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
|
|
(propagated-inputs
|
|
`(("python-agate" ,python-agate)
|
|
("python-crate" ,python-crate)
|
|
("python-sqlalchemy" ,python-sqlalchemy)))
|
|
(home-page "https://agate-sql.rtfd.org")
|
|
(synopsis "SQL read/write support to agate")
|
|
(description "@code{agatesql} uses a monkey patching pattern to add SQL
|
|
support to all @code{agate.Table} instances.")))
|
|
|
|
(define-public python-agate-dbf
|
|
(wireservice-package
|
|
(name "python-agate-dbf")
|
|
(version "0.2.1")
|
|
(source (origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/wireservice/agate-dbf")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"1y49fi6pmm7gzhajvqmfpcca2sqnwj24fqnsvzwk7r1hg2iaa2gi"))))
|
|
(native-inputs
|
|
`(("python-nose" ,python-nose)
|
|
("python-sphinx" ,python-sphinx)
|
|
("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
|
|
(propagated-inputs
|
|
`(("python-agate" ,python-agate)
|
|
("python-dbfread" ,python-dbfread)))
|
|
(home-page "https://agate-dbf.rtfd.org")
|
|
(synopsis "Add read support for dbf files to agate")
|
|
(description "@code{agatedbf} uses a monkey patching pattern to add read
|
|
for dbf files support to all @code{agate.Table} instances.")))
|
|
|
|
(define-public python-agate-excel
|
|
(wireservice-package
|
|
(name "python-agate-excel")
|
|
(version "0.2.5")
|
|
(source (origin
|
|
(method git-fetch)
|
|
(uri (git-reference
|
|
(url "https://github.com/wireservice/agate-excel")
|
|
(commit version)))
|
|
(file-name (git-file-name name version))
|
|
(sha256
|
|
(base32
|
|
"1y3cw57000inwczx50n16kxkr3xi2l241iml1qcqp29a0ba5c519"))))
|
|
(native-inputs
|
|
(list python-nose
|
|
python-sphinx
|
|
python-sphinx-rtd-theme))
|
|
(propagated-inputs
|
|
(list python-agate
|
|
python-olefile
|
|
python-openpyxl
|
|
python-xlrd))
|
|
(home-page "https://agate-excel.rtfd.org")
|
|
(synopsis "Add read support for Excel files (xls and xlsx) to agate")
|
|
(description "@code{agateexcel} uses a monkey patching pattern to add read
|
|
for xls and xlsx files support to all @code{agate.Table} instances.")))
|
|
|
|
(define-public csvkit
|
|
(package
|
|
(name "csvkit")
|
|
(version "1.0.5")
|
|
(source (origin
|
|
(method url-fetch)
|
|
(uri (pypi-uri "csvkit" version))
|
|
(sha256
|
|
(base32
|
|
"1ffmbzk4rxnl1yhqfl58v7kvl5m9cbvjm8v7xp4mvr00sgs91lvv"))))
|
|
(build-system python-build-system)
|
|
(native-inputs
|
|
(list python-psycopg2 ; to test PostgreSQL support
|
|
python-sphinx python-sphinx-rtd-theme))
|
|
(inputs
|
|
(list python-agate-dbf python-agate-excel python-agate-sql
|
|
python-six python-text-unidecode))
|
|
(arguments
|
|
`(#:phases
|
|
(modify-phases %standard-phases
|
|
(add-after 'install 'install-docs
|
|
(lambda* (#:key outputs #:allow-other-keys)
|
|
(let* ((out (assoc-ref outputs "out"))
|
|
(man1 (string-append out "/share/man/man1")))
|
|
(with-directory-excursion "docs"
|
|
(invoke "make" "man")
|
|
(copy-recursively "_build/man" man1))
|
|
#t))))))
|
|
(home-page "https://csvkit.rtfd.org")
|
|
(synopsis "Command-line tools for working with CSV")
|
|
(description "csvkit is a suite of command-line tools for converting to
|
|
and working with CSV. It provides the following commands:
|
|
@itemize
|
|
@item Input:
|
|
@itemize
|
|
@item @command{in2csv}: Convert various formats to CSV.
|
|
@item @command{sql2csv}: Execute SQL commands on a database and return the
|
|
data as CSV.
|
|
@end itemize
|
|
@item Processing:
|
|
@itemize
|
|
@item @command{csvclean}: Remove common syntax errors.
|
|
@item @command{csvcut}: Filter and truncate CSV files.
|
|
@item @command{csvgrep}: Filter tabular data to only those rows where
|
|
certain columns contain a given value or match a regular expression.
|
|
@item @command{csvjoin}: Merges two or more CSV tables together using a
|
|
method analogous to SQL JOIN operation.
|
|
@item @command{csvsort}: Sort CSV files.
|
|
@item @command{csvstack}: Stack up the rows from multiple CSV files,
|
|
optionally adding a grouping value to each row.
|
|
@end itemize
|
|
@item Output and analysis:
|
|
@itemize
|
|
@item @command{csvformat}: Convert a CSV file to a custom output format.
|
|
@item @command{csvjson}: Converts a CSV file into JSON or GeoJSON.
|
|
@item @command{csvlook}: Renders a CSV to the command line in a
|
|
Markdown-compatible, fixed-width format.
|
|
@item @command{csvpy}: Loads a CSV file into a @code{agate.csv.Reader}
|
|
object and then drops into a Python shell so the user can inspect the data
|
|
however they see fit.
|
|
@item @command{csvsql}: Generate SQL statements for a CSV file or execute
|
|
those statements directly on a database.
|
|
@item @command{csvstat}: Prints descriptive statistics for all columns in a
|
|
CSV file.
|
|
@end itemize
|
|
@end itemize")
|
|
(license license:expat)))
|