Need help with pygmt?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

342 Stars 137 Forks BSD 3-Clause "New" or "Revised" License 817 Commits 123 Opened issues


A Python interface for the Generic Mapping Tools.

Services available


Need anything else?

Contributors list


A Python interface for the Generic Mapping Tools

Documentation (development version) 
__ |
__ |
Try Online 

.. image:: :alt: Latest version on PyPI :target: .. image:: :alt: GitHub Actions Tests status :target: .. image:: :alt: GitHub Actions GMT Dev Tests status :target: .. image:: :alt: Test coverage status :target: .. image:: :alt: Compatible Python versions. :target: .. image:: :alt: Discourse forum :target: .. image:: :alt: Digital Object Identifier for the Zenodo archive :target: .. image:: :alt: Contributor Code of Conduct :target:

.. placeholder-for-doc-index

Why PyGMT?

A beautiful map is worth a thousand words. To truly understand how powerful PyGMT is, play with it online on

! But if you need some convincing first, watch this
1 hour introduction 
to PyGMT!

Afterwards, feel free to look at our

__ or visit the
PyGMT Gallery 

.. image:: :alt: Remote Online Sessions for Emerging Seismologists (ROSES): Unit 8 - PyGMT :align: center :target:


🚨 This package is still undergoing rapid development. 🚨

All of the API (functions/classes/interfaces) is subject to change until we reach v1.0.0 as per the

semantic versioning specification 
__. There may be non-backward compatible changes as we experiment with new design ideas and implement new features. This is not a finished product, use with caution.

We welcome any feedback and ideas! Let us know by submitting

issues on GitHub 
__ or by posting on our
Discourse forum 


PyGMT is a library for processing geospatial and geophysical data and making publication quality maps and figures. It provides a Pythonic interface for the

Generic Mapping Tools (GMT) 
__, a command-line program widely used in the Earth Sciences.

We rely heavily on new features that have been implemented in GMT 6.0. In particular, a new modern execution mode that greatly simplifies figure creation. These features are not available in the 5.4 version of GMT.

Project goals

  • Make GMT more accessible to new users.
  • Build a Pythonic API for GMT.
  • Interface with the GMT C API directly using ctypes (no system calls).
  • Support for rich display in the Jupyter notebook.
  • Integration with the
    __ ecosystem:
    for data tables and
    for grids.

Contacting Us

  • Most discussion happens
    on GitHub
    . Feel free to
    open an issue
    or comment on any open issue or pull request.
  • We have a
    Discourse forum
    __ where you can ask questions and leave comments.


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. Equally 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 

Citing PyGMT

PyGMT is a community developed project. See the 
__ file on GitHub for a list of the people involved and a definition of the term "PyGMT Developers". Feel free to cite our work in your research using the following BibTeX:

.. code-block::

  author       = {Uieda, Leonardo and
                  Tian, Dongdong and
                  Leong, Wei Ji and
                  Toney, Liam and
                  Schlitzer, William and
                  Yao, Jiayuan and
                  Grund, Michael and
                  Jones, Meghan and
                  Materna, Kathryn and
                  Newton, Tyler and
                  Ziebarth, Malte and
                  Wessel, Paul},
  title        = {{PyGMT: A Python interface for the Generic Mapping Tools}},
  month        = mar,
  year         = 2021,
  publisher    = {Zenodo},
  version      = {v0.3.1},
  doi          = {10.5281/zenodo.4592991},
  url          = {}

To cite a specific version of PyGMT, go to our Zenodo page at and use the "Export to BibTeX" function there. It is also strongly recommended to cite the

GMT6 paper 
__ (which PyGMT wraps around). Note that some modules like
also have their dedicated citation. Further information for all these can be found at


PyGMT 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



The development of PyGMT has been supported by NSF grants

__ and

Related projects

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

Other Python wrappers for GMT:

  • gmtpy 
    __ by
    Sebastian Heimann 
  • pygmt 
    __ by
    Ian Rose 
  • PyGMT 
    __ by
    Magnus Hagdorn 

Documentation for other versions

  • Development 
    __ (reflects the master branch on GitHub)
  • Latest release 
  • v0.3.1 
  • v0.3.0 
  • v0.2.1 
  • v0.2.0 
  • v0.1.2 
  • v0.1.1 
  • v0.1.0 
  • v0.0.1a0 

Compatibility with GMT and Python/NumPy versions

======= ========== ========= ========= PyGMT GMT Python NumPy ======= ========== ========= ========= 0.4.x >=6.2.0 >=3.7 >=1.17.0 0.3.x >=6.1.1 >=3.7 0.2.1 >=6.1.1 >=3.6 0.2.0 >=6.1.1 3.6 - 3.8 0.1.x >=6.0.0 3.6 - 3.8 ======= ========== ========= =========

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.