Python
Python is one of the most popular programming languages in the world. Its low learning curve paired with a massive ecosystem has made it a powerful tool for geospatial computing. GIS software like QGIS and ArcGIS, provide the ability to extend their functionality through Python, while many programming libraries that have been created to efficiently perform geospatial computing tasks have been either written in Python, released as Python packages, and/or include application programming interfaces (APIs) that coherently communicate with Python code.
If you need recommendations for installing and getting started with Python on your local machine, see Getting Started with Conda, Virtual Environments, and Python.
The following resources will provide general introductions to Python and its applications within data science, so any of them can be useful for learning the basics of Python.
Python Crash Course : UBC Library | WorldCat
Python All-in-One for Dummies : UBC Library | WorldCat
Modern Python Cookbook : UBC Library | WorldCat
Python Tools for Scientists : UBC Library | WorldCat
Data Science Fundamentals with R, Python, and Open Data : UBC Library | WorldCat
Data Visualization in R and Python : UBC Library | WorldCat
If you are looking for a more in-depth introduction to Python, UBC Extended Learning provides multiple courses that can develop confidence in the language while learning best practices for development and maintenance.
Geospatial Books
Carpentries Incubator - Introduction to Geospatial Raster and Vector Data with Python
Learning Geospatial Analysis with Python : UBC Library | WorldCat
Earth Observation Using Python : UBC Library | WorldCat
GIS Algorithms : UBC Library | WorldCat
Python for Geospatial Data Analysis : UBC Library | WorldCat
Applied Geospatial Data Science with Python : UBC Library | WorldCat
Mastering Geospatial Analysis with Python : UBC Library | WorldCat
Machine Learning on Geographical Data Using Python : UBC Library | WorldCat
Extending GIS Software
A Geographer’s Guide to Computing Fundamentals: Python in ArcGIS Pro : UBC Library | WorldCat
Python for ArcGIS Pro : UBC Library | WorldCat
Advanced Python Scripting for ArcGIS Pro : UBC Library | WorldCat
Mastering Geospatial Development with QGIS 3 : UBC Library | WorldCat
QGIS Python Programming Cookbook : UBC Library | WorldCat
Geospatial Libraries/Packages
A relatively comprehensive list of packages can be found in the Python section of Awesome Geospatial.
Many of the packages included in that list provide powerful, easy-to-use functionalities around GDAL. If you need to write code that directly interacts with GDAL, Python bindings are provided, which can be explored through the GDAL documentation.
You may also find some other helpful packages listed in Python for Data Science - Geodata.
Interactive Visualizations and Dashboards
Dashboard libraries enable you to create interactive visualizations from either Python code or Jupyter Notebooks, which can be hosted on sparsely-resourced servers and shared as web applications. You can find information about some of the most popular libraries at PyViz - Dashboarding tools.
Resources for developing interactive maps via a dashboarding library are listed below:
Alternatively, libraries like Voici can similarly convert notebooks to interactive applications, but rather than running the Python code on a server, Voici shifts computation off of the server and into a user’s web browser using WebAssembly (WASM) and a static webpage. This makes hosting the application virtually free via services like GitHub Pages while also making it easier to manage and preserve. The crucial downside to note is that user’s with poor internet connections and/or limited hardware will struggle to run the applications, especially those that include large datasets and long, resource-intensive computations.
Increasing Performance
Compared to other languages, Python isn’t considered particularly fast due to its focus on ease and speed of development over performance. For many geography-based researchers, development workflows first focus on developing code that performs accurate analysis and then later improving the code as needed to ensure the analysis runs as efficiently as possible in both local and HTC environments before finally adapting code to work in an HPC environment if needed.
High Performance Python : UBC Library | WorldCat
Fast Python : UBC Library | WorldCat
Advanced Python Programming : UBC Library | WorldCat
Code Quality Tools
Each of the tools listed below can be easily integrated with most development environments and set up to run automatically. When working with Jupyter Notebooks, we strongly encourage you to install nbqa alongside these tools in order to ensure code quality within your notebooks.
Formatting
Sometimes writing code can get a bit messy. Formatters, like black, can automatically reformat your code to make it cleaner and easier to read while following a set of standards and best practices.
Linting
Using a static analysis tool, or linter, is a common best practice among programmers that helps in identifying and fixings mistakes when writing code by ensuring that you follow the correct syntax and a guiding set of best practices.
Type Checking
While Python is inherently a dynamically typed language, meaning you the programmer don’t have to worry about the data types of each variable, static types can be helpful for reducing bugs when writing complex scripts or programs. Mypy enables programmers to annotate types into their code and returns a helpful error when those types aren’t explicitly followed.
Testing Framework
Similar to type checking, unit testing can be a helpful tool when writing large and complex scripts or programs. Testing frameworks, like pytest, which is included in Python’s standard library, enable you to define tests that can run over your functions and ensure they are following expected behavior in a range of practical scenarios.