Skip to content

jiechencyz/gmt-python

 
 

GMT/Python

A Python interface for the Generic Mapping Tools.

Documentation | Install | Tutorials | API | Contact

Latest version on PyPI Travis CI build status Test coverage status Code quality status Code quality grade on codacy Compatible Python versions. Chat room on Gitter

Disclaimer

This package in early stages of design and implementation.

We welcome any feedback and ideas! Let us know by submitting issues on Github or send us a message on our Gitter chatroom.

Getting started

  1. Try an online demo at try.gmtpython.xyz
  2. Install (tested and working on Linux and OSX)
  3. Follow the Tutorials.
  4. Take a look at the API for a list of modules that are already available.

About

Watch the Scipy 2017 talk about GMT/Python for more information about the history and goals of the project:

YouTube recording of the Scipy2017 talk.

Project goals

  • Build a modern Pythonic API that appeals to Python programmers who want to use GMT.
  • Implement readable and explicit aliases for the GMT command-line arguments (region instead of R, projection instead of J, etc).
  • Use the new GMT modern mode for simplified execution and figure generation.
  • Interface with the GMT C API directly using ctypes (no system calls).
  • Integration with the Jupyter notebook to display plots and maps inline.
  • Input and output using Python native containers: numpy ndarray or pandas DataFrame for data tables and xarray Dataset for netCDF grids.

Contacting Us

Contributing

Code of conduct

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Contributing Guidelines

Please read our Contributing Guide to see how you can help and give feedback.

Imposter syndrome disclaimer

We want your help. No, really.

There may be a little voice inside your head that is telling you that you're not ready to be an open source contributor; that your skills aren't nearly good enough to contribute. What could you possibly offer?

We assure you that the little voice in your head is wrong.

Being a contributor doesn't just mean writing code. Equality important contributions include: writing or proof-reading documentation, suggesting or implementing tests, or even giving feedback about the project (including giving feedback about the contribution process). If you're coming to the project with fresh eyes, you might see the errors and assumptions that seasoned contributors have glossed over. If you can write any code at all, you can contribute code to open source. We are constantly trying out new skills, making mistakes, and learning from those mistakes. That's how we all improve and we are happy to help others learn.

This disclaimer was adapted from the MetPy project.

Related projects

  • GMT.jl -- A Julia wrapper for GMT.
  • gmtmex -- A Matlab/Octave wrapper for GMT.

Other Python wrappers for GMT:

License

gmt-python is free software: you can redistribute it and/or modify it under the terms of the BSD 3-clause License. A copy of this license is provided in LICENSE.txt.

About

A Python interface for the Generic Mapping Tools

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 98.5%
  • Other 1.5%