mirror of
https://github.com/almet/notmyidea.git
synced 2025-04-28 19:42:37 +02:00
255 lines
No EOL
10 KiB
HTML
255 lines
No EOL
10 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
|
<meta http-equiv="content-type" content="text/html; charset=utf-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1">
|
|
<link rel="shortcut icon" type="image/x-icon" href="favicon.ico" />
|
|
|
|
<title>PyconFR 2015 — Geoalchemy - Alexis - Carnets en ligne</title>
|
|
|
|
<meta charset="utf-8" />
|
|
<link href="https://blog.notmyidea.org/feeds/all.atom.xml" type="application/atom+xml" rel="alternate" title="Alexis - Carnets en ligne Full Atom Feed" />
|
|
<link rel="stylesheet" href="https://blog.notmyidea.org/theme/css/poole.css"/>
|
|
<link rel="stylesheet" href="https://blog.notmyidea.org/theme/css/syntax.css"/>
|
|
<link rel="stylesheet" href="https://blog.notmyidea.org/theme/css/lanyon.css"/>
|
|
<link rel="stylesheet" href="//fonts.googleapis.com/css?family=PT+Serif:400,400italic,700%7CPT+Sans:400">
|
|
<link rel="stylesheet" href="https://blog.notmyidea.org/theme/css/styles.css"/>
|
|
|
|
|
|
|
|
<style>
|
|
|
|
h1 {
|
|
font-family: "Avant Garde", Avantgarde, "Century Gothic", CenturyGothic, "AppleGothic", sans-serif;
|
|
padding: 80px 50px;
|
|
text-align: center;
|
|
text-transform: uppercase;
|
|
text-rendering: optimizeLegibility;
|
|
color: #202020;
|
|
letter-spacing: .1em;
|
|
text-shadow:
|
|
-1px -1px 1px #111,
|
|
2px 2px 1px #eaeaea;
|
|
}
|
|
|
|
#main {
|
|
text-align: justify;
|
|
text-justify: inter-word;
|
|
}
|
|
#main h1 {
|
|
padding: 10px;
|
|
}
|
|
|
|
.post-headline {
|
|
padding: 15px;
|
|
text-align: center;
|
|
}
|
|
</style>
|
|
</head>
|
|
|
|
<body>
|
|
<!-- Target for toggling the sidebar `.sidebar-checkbox` is for regular
|
|
styles, `#sidebar-checkbox` for behavior. -->
|
|
<input type="checkbox" class="sidebar-checkbox" id="sidebar-checkbox">
|
|
<!-- Toggleable sidebar -->
|
|
<div class="sidebar" id="sidebar">
|
|
<div class="sidebar-item">
|
|
<div class="profile">
|
|
<img src="https://blog.notmyidea.org/theme/img/profile.png"/>
|
|
</div>
|
|
</div>
|
|
|
|
<nav class="sidebar-nav">
|
|
<a class="sidebar-nav-item" href="/">Articles</a>
|
|
|
|
<a class="sidebar-nav-item" href="https://www.vieuxsinge.com">Brasserie du Vieux Singe</a>
|
|
<a class="sidebar-nav-item" href="http://blog.notmyidea.org/pages/about.html">A propos</a>
|
|
<a class="sidebar-nav-item" href="https://twitter.com/ametaireau">Messages courts</a>
|
|
<a class="sidebar-nav-item" href="https://github.com/almet">Code</a>
|
|
</nav>
|
|
</div> <div class="wrap">
|
|
<div class="masthead">
|
|
<div class="container">
|
|
<h3 class="masthead-title">
|
|
<a href="https://blog.notmyidea.org/" title="Home">Alexis - Carnets en ligne</a>
|
|
</h3>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="container content">
|
|
<div id="main" class="posts">
|
|
<h1 class="post-title">PyconFR 2015 — Geoalchemy</h1>
|
|
|
|
<span class="post-date">
|
|
17 octobre 2015, dans <a class="no-color" href="category/pyconfr2015.html">pyconfr2015</a>
|
|
</span>
|
|
<img id="illustration" class="illustration-pyconfr2015" src="" />
|
|
|
|
<div class="post article">
|
|
<h1>🌟</h1>
|
|
<div class="admonition note">
|
|
<p class="first admonition-title">Note</p>
|
|
<p class="last">Voici quelques notes prises durant la PyconFR 2015, à Pau. N'hésitez pas
|
|
à les completer si besoin.</p>
|
|
</div>
|
|
<p>Speaker: Eric Lemoine, Camp to camp. (@elemoine)</p>
|
|
<p>Bibliothèque python basée sur SQL alchemy, pour interagir avec des bases de
|
|
données geographiques / spatiales.</p>
|
|
<p>Une base de donnée optimisée pour representer et rechercher des données qui
|
|
representent des objets dans un espace géométrique.</p>
|
|
<ul class="simple">
|
|
<li>Il est possible d estocker des ligne,s de polygones, des points. Il y a une
|
|
colonne géometrie pour stocker ces données.</li>
|
|
<li>Il y a aussi des fonctions qui permettent de travailler sur ces données
|
|
(transfomrations, projections, etc).</li>
|
|
<li>Indexs géographiques qui permettent de faire des recherches de manière
|
|
performante.</li>
|
|
</ul>
|
|
<div class="section" id="postgis">
|
|
<h2>POSTGIS</h2>
|
|
<p>POSTGIS s'appuie sur postres pour offrir des types géographiques, des fonctions
|
|
et des indexes (R-Tree), qui permettent de ranger les géométries dans des
|
|
"boites englobantes".</p>
|
|
<p>Pour créer une base de données postgis, il faut faire un "create extension
|
|
postgis", ce qui installe tout ce dont on a besoin.</p>
|
|
<p>il est possible d'apeller <cite>GEOMETRY(POINT)</cite> par exemple.</p>
|
|
<p><cite>ST_GeomFromText('POINT(lat long)')</cite> permet de convertir un point dans un objet
|
|
geometrie interne à postgres.</p>
|
|
<p><cite>ST_DWithin</cite> permet de trouver les personnes qui sont autour d'un rayon donné.</p>
|
|
<p>L'ensemble des fonctions proposées par postgres commencent par <cite>ST_*</cite></p>
|
|
</div>
|
|
<div class="section" id="sqlalchemy">
|
|
<h2>SQLAlchemy</h2>
|
|
<p>Il s'agit d'une bote à outil qui permet de faire des requetes de manière
|
|
simple. Il y a une philosophie forte.</p>
|
|
<ul class="simple">
|
|
<li>Il ne sohaite pas cacher la base de données</li>
|
|
<li>C'est un language pour faire du SQL en python</li>
|
|
<li>Rien n'est caché.</li>
|
|
<li>Fourni un vocabulaire riche pour générer le SQL</li>
|
|
<li>L'objectif est de changer la manière dont on pense à SQL, redonner le gout du
|
|
SQL aux developeurs.</li>
|
|
</ul>
|
|
<p>Deux parties:
|
|
- ORM
|
|
- CORE</p>
|
|
<p>Il est possible d'utiliser simplement le core si l'on sohaite (sans utiliser
|
|
l'ORM)</p>
|
|
<div class="section" id="core">
|
|
<h3>Core</h3>
|
|
<p>Il est possible d'utiliser SQL Alchemy pour générer les tables à l'origine.
|
|
Core permet d'utiliser des tables, et d'executer une insertion, depuis python.
|
|
Il est possible de representer les requetes avec des methodes chainées
|
|
<cite>select().where()</cite> etc.</p>
|
|
<p>Le "core" ne fait pas de mapping du tout, il manipule des Tables SQLA
|
|
directement.</p>
|
|
</div>
|
|
<div class="section" id="orm">
|
|
<h3>ORM</h3>
|
|
<p>L'ORM fait, lui, du mapping. C'est cette couche que l'on va utiliser dans une
|
|
application Web complexe par exemple.</p>
|
|
<ul class="simple">
|
|
<li>il est possible de travailler avec une session <cite>Session()</cite> puis on effectue
|
|
des opérations et on <cite>commit()</cite>.</li>
|
|
</ul>
|
|
<div class="section" id="geoalchemy">
|
|
<h4>GeoAlchemy</h4>
|
|
<ul class="simple">
|
|
<li>Créé en 2009, pour supporter uniquement postgis.</li>
|
|
<li>Depuis, d'autres bases de données (MySQL, Spatialite, MySQL server) etc.</li>
|
|
<li>Réécriture depuis grace à la nouvelle API de SQLAlechemy, mais perte du
|
|
support d'autres backends.</li>
|
|
<li>Finalement, retour sur POSTGIS uniquement, pour évite d'avoir à supporter les
|
|
différences de tous les backends.</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="section" id="features">
|
|
<h2>Features</h2>
|
|
<p>Très simple de s'intégrer avec les features de POSTGIS, par exemple en
|
|
déclarant une colonne en tant que "Géometrie".</p>
|
|
<p>Exemple: session.query(Lake).filter(Lake.geom.ST_Buffer(2).ST_Area) permet de
|
|
lister l'ensemble des lacs avec une aire de 2 au moins.</p>
|
|
<p>S'intègre bien avec des services existants (shapely, pyramid, etc).</p>
|
|
<p>Utilisation de geojsondumps pour representer des features en geojson.</p>
|
|
</div>
|
|
<div class="section" id="status">
|
|
<h2>Status</h2>
|
|
<p>Le projet est completement documenté sur read the docs. La documentation est
|
|
assez complete et solide. Il est intégralement testé, sur differentes versions
|
|
de python, sqlalchemy et postgres.</p>
|
|
<dl class="docutils">
|
|
<dt>3 ou 4 developeurs actifs sur le projet, ça fonctionne plutôt bien. Pour</dt>
|
|
<dd><p class="first">contribuer, il est possible de faire cela sur github.</p>
|
|
<p class="last">Slides de la presentation sur <a class="reference external" href="http://erliem.net/talks/pyconfr2015">http://erliem.net/talks/pyconfr2015</a></p>
|
|
</dd>
|
|
</dl>
|
|
<p>Resources:</p>
|
|
<ul class="simple">
|
|
<li><a class="reference external" href="https://pypi.python.org/pypi/Shapely">https://pypi.python.org/pypi/Shapely</a> - Manipulation and analysis of geometric
|
|
objects in the Cartesian plane.</li>
|
|
</ul>
|
|
<p>Question:</p>
|
|
<ul class="simple">
|
|
<li>Dans les exemples geoalchemy, les données geométriques sont passées sous
|
|
forme de chaine. Est-ce normal ? Oui.</li>
|
|
<li>Les rasters sont également supportés.</li>
|
|
</ul>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<label for="sidebar-checkbox" class="sidebar-toggle"></label>
|
|
|
|
<script>
|
|
(function(document) {
|
|
var i = 0;
|
|
// snip empty header rows since markdown can't
|
|
var rows = document.querySelectorAll('tr');
|
|
for(i=0; i<rows.length; i++) {
|
|
var ths = rows[i].querySelectorAll('th');
|
|
var rowlen = rows[i].children.length;
|
|
if (ths.length > 0 && ths.length === rowlen) {
|
|
rows[i].remove();
|
|
}
|
|
}
|
|
})(document);
|
|
</script>
|
|
|
|
<script>
|
|
/* Lanyon & Poole are Copyright (c) 2014 Mark Otto. Adapted to Pelican 20141223 and extended a bit by @thomaswilley */
|
|
(function(document) {
|
|
var toggle = document.querySelector('.sidebar-toggle');
|
|
var sidebar = document.querySelector('#sidebar');
|
|
var checkbox = document.querySelector('#sidebar-checkbox');
|
|
document.addEventListener('click', function(e) {
|
|
var target = e.target;
|
|
if(!checkbox.checked ||
|
|
sidebar.contains(target) ||
|
|
(target === checkbox || target === toggle)) return;
|
|
checkbox.checked = false;
|
|
}, false);
|
|
})(document);
|
|
</script>
|
|
<!-- Piwik -->
|
|
<script type="text/javascript">
|
|
var _paq = _paq || [];
|
|
_paq.push(['trackPageView']);
|
|
_paq.push(['enableLinkTracking']);
|
|
(function() {
|
|
var u="//tracker.notmyidea.org/";
|
|
_paq.push(['setTrackerUrl', u+'piwik.php']);
|
|
_paq.push(['setSiteId', 3]);
|
|
var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
|
|
g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'piwik.js'; s.parentNode.insertBefore(g,s);
|
|
})();
|
|
</script>
|
|
<noscript><p><img src="//tracker.notmyidea.org/piwik.php?idsite=3" style="border:0;" alt="" /></p></noscript>
|
|
<!-- End Piwik Code -->
|
|
</div>
|
|
</body>
|
|
</html> |