* gnu/packages/wireservice.scm (csvkit): Update to 1.1.1. Signed-off-by: Ludovic Courtès <ludo@gnu.org>
		
			
				
	
	
		
			276 lines
		
	
	
	
		
			11 KiB
		
	
	
	
		
			Scheme
		
	
	
	
	
	
			
		
		
	
	
			276 lines
		
	
	
	
		
			11 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 base)
 | |
|   #: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 python-agate-locales
 | |
|   (make-glibc-utf8-locales
 | |
|    glibc
 | |
|    #:locales (list "ko_KR")
 | |
|    #:name "python-agate-locales"))
 | |
| 
 | |
| (define-public python-agate
 | |
|   (wireservice-package
 | |
|    (name "python-agate")
 | |
|    (version "1.7.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
 | |
|                "1wqyml7f70hr7zhgwvwqy4bdshlbcmp4jmyc5y12jyx10xp3sk7c"))))
 | |
|    (native-inputs
 | |
|     `(("locales" ,python-agate-locales)
 | |
|       ("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.9")
 | |
|    (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
 | |
|                "112q523w4jf3k8p4ynvjzfqa4j32ri34h2ppvicialp2lz5drvf0"))))
 | |
|    (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.2")
 | |
|    (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
 | |
|                "03l3qlyw7588jhjjsiy15valqlzs8gjai8f74v18zv2za0zjqbzl"))))
 | |
|    (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.1.1")
 | |
|     (source (origin
 | |
|               (method url-fetch)
 | |
|               (uri (pypi-uri "csvkit" version))
 | |
|               (sha256
 | |
|                (base32
 | |
|                 "08wj0hlmbdmklar12cjzqp91vcxzwifsvmgasszas8kbiyvvgpdy"))))
 | |
|     (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)))
 |