A Python interface for the Generic Mapping Tools.
Documentation | Install | Tutorials | API | Contact
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.
- Try an online demo at try.gmtpython.xyz
- Install (tested and working on Linux and OSX)
- Follow the Tutorials.
- Take a look at the API for a list of modules that are already available.
Watch the Scipy 2017 talk about GMT/Python for more information about the history and goals of the project:
- 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 ofR
,projection
instead ofJ
, 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 pandasDataFrame
for data tables and xarrayDataset
for netCDF grids.
- Most discussion happens on Github. Feel free to open an issue or comment on any open issue or pull request.
- We have chat room on Gitter where you can ask questions and leave comments.
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.
Please read our Contributing Guide to see how you can help and give feedback.
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.
Other Python wrappers for GMT:
- gmtpy by Sebastian Heimann
- pygmt by Ian Rose
- PyGMT by Magnus Hagdorn
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
.