forked from pythonclub/pythonclub.github.io
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpostgresql-e-python3.html
More file actions
274 lines (244 loc) · 23.2 KB
/
postgresql-e-python3.html
File metadata and controls
274 lines (244 loc) · 23.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="PythonClub, ">
<meta name="theme-color" content="#101212">
<link rel="alternate" href="http://pythonclub.com.br/feeds/all.atom.xml" type="application/atom+xml" title="PythonClub Full Atom Feed"/>
<link rel="alternate" href="http://pythonclub.com.br/feeds/all.rss.xml" type="application/rss+xml" title="PythonClub Full RSS Feed"/>
<link rel="shortcut icon" href="http://pythonclub.com.br/theme/images/favicon.ico" >
<title>PostgreSql e Python3 - parte 2 por Regis da Silva // #PythonClub // </title>
<meta property="fb:app_id" content="1487080281503641" />
<meta property="og:type" content="article" />
<meta property="og:title" content="PostgreSql e Python3 - parte 2" />
<meta property="og:site_name" content="PythonClub" />
<meta property="og:url" content="http://pythonclub.com.br/postgresql-e-python3.html" />
<meta property="og:description" content="Esta é a parte 2 (de 3) da série de posts sobre PostgreSql..." />
<meta property="og:image" content="http://res.cloudinary.com/diu8g9l0s/image/upload/v1400201393/pythonclub/logo_275x130.png" />
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/pure/0.3.0/pure-min.css">
<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/font-awesome/4.0.3/css/font-awesome.min.css">
<link rel="stylesheet" href="http://pythonclub.com.br/theme/css/pure.css">
<link rel="stylesheet" href="http://pythonclub.com.br/theme/css/custom.css">
<link rel="stylesheet" href="http://pythonclub.com.br/theme/css/pygments.css">
<script>
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
ga('create', 'UA-50935105-1', 'pythonclub.com.br');
ga('require', 'linkid', 'linkid.js');
ga('send', 'pageview');
</script>
<!-- transifex -->
<!-- <script type="text/javascript"> -->
<!-- window.liveSettings = { -->
<!-- api_key: "f8fd260a9bdc4e9195c80e31416bb254", -->
<!-- picker: "bottom-right", -->
<!-- detectlang: true, -->
<!-- autocollect: true -->
<!-- }; -->
<!-- </script> -->
<!-- <script type="text/javascript" src="//cdn.transifex.com/live.js"></script> -->
<!-- end transifex -->
<meta name="google-site-verification" content="XQc_QtnTecI9nxAfplXGtECCpZQDwbDRcn7pyDVa1LE" />
</head>
<body>
<div class="pure-g-r" id="layout">
<div class="sidebar sidebar-article pure-u">
<header class="header-article">
<hgroup>
<a href="http://pythonclub.com.br/author/regis-da-silva.html" title="See posts by Regis da Silva">
<img class="article-avatar" alt="Regis da Silva" src="http://www.gravatar.com/avatar/2a2df360031bb022af11138a2a4a8db9">
</a>
<h2 class="article-info">Regis da Silva</h2>
<ul class="author-social">
<li>
<a target="_blank" href="https://github.com/rg3915">
<i class="fa fa-lg fa-fw fa-github"></i>
<strong>Github</strong>
</a>
</li>
</ul>
<h5>Publicado em:</h5>
<p>Tue 17 February 2015</p>
<a href="/">←Home</a>
</hgroup>
</header>
</div>
<div class="pure-u">
<div class="content">
<section class="post">
<header class="post-header">
<h1>PostgreSql e Python3 - parte 2</h1>
<p class="post-meta">
// Tags <a class="post-category" href="http://pythonclub.com.br/tag/python.html">python</a>
<a class="post-category" href="http://pythonclub.com.br/tag/postresql.html">postresql</a>
<a class="post-category" href="http://pythonclub.com.br/tag/banco-de-dados.html">banco de dados</a>
</p>
</header>
</section>
<p>Se você já leu o <a class="reference external" href="http://pythonclub.com.br/tutorial-postgresql.html">Tutorial Postgresql - parte 1</a> este post é uma continuação. Aqui nós veremos como manipular um banco de dados PostgreSql no Python3.</p>
<div class="figure">
<img alt="postgresql_python.png" src="/images/regisdasilva/postgresql_python.png" />
</div>
<p>Além da instalação mostrada no primeiro post precisaremos de</p>
<div class="highlight"><pre><span class="nv">$ </span>sudo apt-get install python-psycopg2 <span class="c"># para python2</span>
<span class="c"># ou</span>
<span class="nv">$ </span>sudo apt-get install python3-psycopg2 <span class="c"># para python3</span>
</pre></div>
<p>Começando...</p>
<div class="highlight"><pre><span class="nv">$ </span>sudo su - postgres
</pre></div>
<p>Veja o prompt:</p>
<div class="highlight"><pre>postgres@myuser:~<span class="err">$</span>
</pre></div>
<p>Criando o banco</p>
<div class="highlight"><pre><span class="nv">$ </span>createdb mydb
</pre></div>
<p>Se existir o banco faça</p>
<div class="highlight"><pre><span class="nv">$ </span>dropdb mydb
</pre></div>
<p>e crie novamente. Para sair digite</p>
<div class="highlight"><pre><span class="nv">$ </span><span class="nb">exit</span>
</pre></div>
<p>Abra o python3.</p>
<div class="highlight"><pre><span class="nv">$ </span>python3
Python 3.4.0 <span class="o">(</span>default, Apr <span class="m">11</span> 2014, 13:05:18<span class="o">)</span>
<span class="o">[</span>GCC 4.8.2<span class="o">]</span> on linux
Type <span class="s2">"help"</span>, <span class="s2">"copyright"</span>, <span class="s2">"credits"</span> or <span class="s2">"license"</span> <span class="k">for</span> more information.
>>>
</pre></div>
<p>Importe o psycopg2</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="kn">import</span> <span class="nn">psycopg2</span>
</pre></div>
<p>Conectando a um banco de dados existente</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">conn</span> <span class="o">=</span> <span class="n">psycopg2</span><span class="o">.</span><span class="n">connect</span><span class="p">(</span><span class="s">"dbname=mydb user=myuser"</span><span class="p">)</span>
</pre></div>
<p>Abrindo um cursor para manipular o banco</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">cur</span> <span class="o">=</span> <span class="n">conn</span><span class="o">.</span><span class="n">cursor</span><span class="p">()</span>
</pre></div>
<p>Criando uma nova tabela</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">cur</span><span class="o">.</span><span class="n">execute</span><span class="p">(</span><span class="s">"CREATE TABLE person (id serial PRIMARY KEY, name text, age integer);"</span><span class="p">)</span>
</pre></div>
<p>Inserindo dados.O Psycopg faz a conversão correta. Não mais injeção SQL.</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">cur</span><span class="o">.</span><span class="n">execute</span><span class="p">(</span><span class="s">"INSERT INTO person (name, age) VALUES (</span><span class="si">%s</span><span class="s">, </span><span class="si">%s</span><span class="s">)"</span><span class="p">,(</span><span class="s">"O'Relly"</span><span class="p">,</span> <span class="mi">60</span><span class="p">))</span>
<span class="o">>>></span> <span class="n">cur</span><span class="o">.</span><span class="n">execute</span><span class="p">(</span><span class="s">"INSERT INTO person (name, age) VALUES (</span><span class="si">%s</span><span class="s">, </span><span class="si">%s</span><span class="s">)"</span><span class="p">,(</span><span class="s">'Regis'</span><span class="p">,</span> <span class="mi">35</span><span class="p">))</span>
</pre></div>
<p>Grava as alterações no banco</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">conn</span><span class="o">.</span><span class="n">commit</span><span class="p">()</span>
</pre></div>
<p># Select</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">cur</span><span class="o">.</span><span class="n">execute</span><span class="p">(</span><span class="s">"SELECT * FROM person;"</span><span class="p">)</span>
<span class="o">>>></span> <span class="n">cur</span><span class="o">.</span><span class="n">fetchall</span><span class="p">()</span>
</pre></div>
<p>Fecha a comunicação com o banco</p>
<div class="highlight"><pre><span class="o">>>></span> <span class="n">cur</span><span class="o">.</span><span class="n">close</span><span class="p">()</span>
<span class="o">>>></span> <span class="n">conn</span><span class="o">.</span><span class="n">close</span><span class="p">()</span>
<span class="o">>>></span> <span class="nb">exit</span><span class="p">()</span>
</pre></div>
<p>Leia também</p>
<p><a class="reference external" href="http://pythonclub.com.br/tutorial-postgresql.html">Tutorial Postgresql - parte 1</a></p>
<p><a class="reference external" href="http://pythonclub.com.br/postgresql-e-django.html">PostgreSql e Django - parte 3</a></p>
<p><a class="reference external" href="http://initd.org/psycopg/docs/">http://initd.org/psycopg/docs/</a></p>
<p><a class="reference external" href="http://initd.org/psycopg/docs/usage.html">http://initd.org/psycopg/docs/usage.html</a></p>
<div class="licence">
<a rel="license" href="http://creativecommons.org/licenses/by-nc-nd/4.0/"><img alt="Licença Creative Commons"
style="border-width:0"
src="http://i.creativecommons.org/l/by-nc-nd/4.0/88x31.png"/></a><br/><a
xmlns:dct="http://purl.org/dc/terms/" property="dct:title"
href="http://pythonclub.com.br/postgresql-e-python3.html">"PostgreSql e Python3 - parte 2"</a> de <a
xmlns:cc="http://creativecommons.org/ns#" href="http://pythonclub.com.br/author/regis-da-silva.html"
property="cc:attributionName" rel="cc:attributionURL">"Regis da Silva"</a> está licenciado com uma Licença
<a rel="license" href="http://creativecommons.org/licenses/by-nc-nd/4.0/">Creative Commons -
Atribuição-NãoComercial-SemDerivações 4.0 Internacional</a>.
</div>
<div class="sharing">
<!-- Facebook sharing -->
<div id="fb-root"></div>
<script>(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/pt_BR/sdk.js#xfbml=1&appId=1487080281503641&version=v2.0";
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));</script>
<div class="fb-share-button" data-href="http://pythonclub.com.br/postgresql-e-python3.html" data-type="button_count"></div>
<!-- Google+ sharing -->
<div class="g-plus alinhar" data-action="share" data-annotation="bubble" data-href="http://pythonclub.com.br/postgresql-e-python3.html"></div>
<!-- Twitter sharing -->
<a href="https://twitter.com/share" class="twitter-share-button" data-lang="pt" style="margin-bottom: -4px !important;">Tweetar</a>
<script>!function(d,s,id){var js,fjs=d.getElementsByTagName(s)[0],p=/^http:/.test(d.location)?'http':'https';if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src=p+'://platform.twitter.com/widgets.js';fjs.parentNode.insertBefore(js,fjs);}}(document, 'script', 'twitter-wjs');</script>
</div>
<div class="hr"></div>
<a href="#" class="go-top">Topo</a>
<div class="comments">
<div id="disqus_thread"></div>
<script type="text/javascript">
/* * * CONFIGURATION VARIABLES: THIS CODE IS ONLY AN EXAMPLE * * */
var disqus_shortname = 'pythonclub'; // Required - Replace example with your forum shortname
var disqus_identifier = 'postgresql-e-python3.html';
var disqus_title = 'PostgreSql e Python3 - parte 2';
var disqus_url = 'http://pythonclub.com.br/postgresql-e-python3.html';
/* * * DON'T EDIT BELOW THIS LINE * * */
(function() {
var dsq = document.createElement('script'); dsq.type = 'text/javascript'; dsq.async = true;
dsq.src = '//' + disqus_shortname + '.disqus.com/embed.js';
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
})();
</script>
<noscript>Please enable JavaScript to view the <a href="http://disqus.com/?ref_noscript">comments powered by Disqus.</a></noscript>
<a href="http://disqus.com" class="dsq-brlink">comments powered by <span class="logo-disqus">Disqus</span></a>
</div>
<footer class="footer">
<p>© PythonClub –
Built with <a href="https://github.com/PurePelicanTheme/pure">Pure Theme</a>
for <a href="http://blog.getpelican.com/">Pelican</a>
</p>
</footer> </div>
</div>
</div>
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script src="http://pythonclub.com.br/theme/js/dynamic_random_articles.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/fitvids/1.0.1/jquery.fitvids.min.js"></script>
<script>
$(document).ready(function(){
$(".content").fitVids();
});
$(window).load(function(){
$("iframe").css("margin-bottom", "-6px")
$("#twitter-widget-0").css("margin-bottom", "-5px");
$("#twitter-widget-0").css("margin-left", "-1px");
});
</script>
<script type="text/javascript" src="https://apis.google.com/js/platform.js">
{lang: 'pt-BR'}
</script>
<script>
var $top = $('.go-top');
// Show or hide the sticky footer button
$(window).scroll(function() {
if ($(this).scrollTop() > 200) {
$top.fadeIn(200);
} else {
$top.fadeOut(200);
}
});
// Animate the scroll to top
$top.click(function(event) {
event.preventDefault();
$('html, body').animate({scrollTop: 0}, 300);
})
// Makes sure that the href="#" attached to the <a> elements
// don't scroll you back up the page.
$('body').on('click', 'a[href="#"]', function(event) {
event.preventDefault();
});
$(function(){
show_random_articles($('#random-articles'), [{"url": "http://pythonclub.com.br/raspando-a-web-com-python-parte-1.html", "title": "Raspando a Web com Python: Introdu\u00e7\u00e3o"}, {"url": "http://pythonclub.com.br/instalando-pycharm-ubuntu.html", "title": "Instalando o PyCharm no Ubuntu (e irm\u00e3os)"}, {"url": "http://pythonclub.com.br/a-armadilha-dos-argumentos-com-valores-padrao.html", "title": "A armadilha dos argumentos com valores padr\u00e3o"}, {"url": "http://pythonclub.com.br/desenvolvendo-para-google-app-engine-com-tekton.html", "title": "Cria\u00e7\u00e3o de aplica\u00e7\u00f5es no Google App Engine com o Tekton"}, {"url": "http://pythonclub.com.br/django-introducao-queries.html", "title": "Como otimizar suas consultas no Django - De N a 1 em 20 minutos"}, {"url": "http://pythonclub.com.br/django-overview-10-minutos.html", "title": "Django - 3 anos em 10 minutos"}, {"url": "http://pythonclub.com.br/configurando-ambiente-django-com-apache-e-mod-wsgi.html", "title": "Configurando ambiente Django com Apache e mod_wsgi"}, {"url": "http://pythonclub.com.br/tuplas-mutantes-em-python.html", "title": "Tuplas mutantes em Python"}, {"url": "http://pythonclub.com.br/postgresql-e-django.html", "title": "PostgreSql e Django - parte 3"}, {"url": "http://pythonclub.com.br/postgresql-e-python3.html", "title": "PostgreSql e Python3 - parte 2"}, {"url": "http://pythonclub.com.br/microframework-contra-baterias-incluidas.html", "title": "Microframework contra "Baterias Inclu\u00eddas""}, {"url": "http://pythonclub.com.br/debugging-em-python-sem-ide.html", "title": "Debugging em python (sem IDE)"}, {"url": "http://pythonclub.com.br/tutorial-postgresql.html", "title": "Tutorial PostgreSql - parte 1"}, {"url": "http://pythonclub.com.br/conteinerizando-suas-aplicacoes-django-com-docker-e-fig.html", "title": "Conteinerizando suas aplica\u00e7\u00f5es django com docker e fig"}, {"url": "http://pythonclub.com.br/publicando-seu-hello-world-no-heroku.html", "title": "Publicando seu Hello World no Heroku"}, {"url": "http://pythonclub.com.br/entrevista-henrique-bastos.html", "title": "Entrevista com Henrique Bastos"}, {"url": "http://pythonclub.com.br/testes-de-carga-com-o-locust.html", "title": "Testes de carga com o Locust"}, {"url": "http://pythonclub.com.br/tutorial-django-17.html", "title": "Tutorial Django 1.7"}, {"url": "http://pythonclub.com.br/integrando-django-com-cloudinary.html", "title": "Integrando o Django com Cloudinary"}, {"url": "http://pythonclub.com.br/bottle-framework-full-stack-sem-django.html", "title": "Bottle Framework full stack sem Django"}, {"url": "http://pythonclub.com.br/desenvolvendo-com-bottle-parte-1.html", "title": "Desenvolvendo com Bottle - Parte 1"}, {"url": "http://pythonclub.com.br/gerenciando-banco-dados-sqlite3-python-parte2.html", "title": "Gerenciando banco de dados SQLite3 com Python - Parte 2"}, {"url": "http://pythonclub.com.br/solucao-quase-definitiva-para-permissoes-em-projetos-django.html", "title": "Solu\u00e7\u00e3o (quase) definitiva para permiss\u00f5es em projetos Django"}, {"url": "http://pythonclub.com.br/gerenciando-assets-com-django-pipeline.html", "title": "Gerenciando assets com django-pipeline"}, {"url": "http://pythonclub.com.br/deploy-app-django-openshift.html", "title": "Deploy App Django no Openshift"}, {"url": "http://pythonclub.com.br/criando-sites-estaticos-com-pelican.html", "title": "Criando sites est\u00e1ticos com Pelican Framework"}, {"url": "http://pythonclub.com.br/selenium-parte-4.html", "title": "Selenium - O que voc\u00ea deveria saber - Parte 4"}, {"url": "http://pythonclub.com.br/configurando-um-servidor-de-producao-para-aplicacoes-python.html", "title": "Configurando um servidor de produ\u00e7\u00e3o para aplica\u00e7\u00f5es Python"}, {"url": "http://pythonclub.com.br/what-the-flask-pt-2-flask-patterns-boas-praticas-na-estrutura-de-aplicacoes-flask.html", "title": "What the Flask? Pt-2 Flask Patterns - boas pr\u00e1ticas na estrutura de aplica\u00e7\u00f5es Flask"}, {"url": "http://pythonclub.com.br/gerenciando-banco-dados-sqlite3-python-parte1.html", "title": "Gerenciando banco de dados SQLite3 com Python - Parte 1"}, {"url": "http://pythonclub.com.br/introducao-classes-metodos-python-basico.html", "title": "Introdu\u00e7\u00e3o a Classes e M\u00e9todos em Python (b\u00e1sico)"}, {"url": "http://pythonclub.com.br/pyftpdlib-criando-um-servidor-ftp-simples-com-python.html", "title": "pyftpdlib - Criando um servidor FTP simples com python"}, {"url": "http://pythonclub.com.br/usando-redis-cache-django.html", "title": "Usando Redis para cache e sess\u00e3o do Django"}, {"url": "http://pythonclub.com.br/aprendendo-e-ensinando-python.html", "title": "Aprendendo e Ensinando Python"}, {"url": "http://pythonclub.com.br/selenium-parte-3.html", "title": "Selenium - O que voc\u00ea deveria saber - Parte 3"}, {"url": "http://pythonclub.com.br/what-the-flask-pt-1-introducao-ao-desenvolvimento-web-com-python.html", "title": "What the Flask? Pt-1 Introdu\u00e7\u00e3o ao desenvolvimento web com Python"}, {"url": "http://pythonclub.com.br/selenium-parte-2.html", "title": "Selenium - O que voc\u00ea deveria saber - Parte 2"}, {"url": "http://pythonclub.com.br/guia-rapido-comandos-sqlite3.html", "title": "Guia r\u00e1pido de comandos SQLite3"}, {"url": "http://pythonclub.com.br/editando-o-admin-do-django.html", "title": "Editando o Admin do Django"}, {"url": "http://pythonclub.com.br/instalacao-python-django-windows.html", "title": "Instalando e Configurando o Python e Django no Windows"}, {"url": "http://pythonclub.com.br/criar-site-com-form-lista-30-min.html", "title": "Como criar um site com formul\u00e1rio e lista em 30 minutos?"}, {"url": "http://pythonclub.com.br/principais-duvidas-de-quem-quer-aprender-django.html", "title": "Principais d\u00favidas de quem quer aprender Django"}, {"url": "http://pythonclub.com.br/parseando-sites-com-beautifulsoup.html", "title": "Exemplo de como "Parsear" Sites com BeautifulSoup"}, {"url": "http://pythonclub.com.br/deploy-com-django-fagungis.html", "title": "Publica\u00e7\u00e3o de projetos com o Django-Fagungis"}, {"url": "http://pythonclub.com.br/como-fazer-fork-clone-push-pull-request-no-github.html", "title": "Como fazer fork, clone, push pull-request no Github"}, {"url": "http://pythonclub.com.br/primeiro-projeto-django-no-linux-com-sublime.html", "title": "Seu primeiro projeto Django com Sublime Text no Linux"}, {"url": "http://pythonclub.com.br/introducao-a-testes-funcionais-com-selenium-e-python.html", "title": "Introdu\u00e7\u00e3o a testes funcionais com Selenium e Python"}, {"url": "http://pythonclub.com.br/selenium-parte-1.html", "title": "Selenium - O que voc\u00ea deveria saber - Parte 1"}, {"url": "http://pythonclub.com.br/5-django-apps-que-nao-vivo-se.html", "title": "5 Django Apps que n\u00e3o vivo sem"}, {"url": "http://pythonclub.com.br/sobre-o-six-e-como-ele-ajuda-a-escrever-codigo-compativel-com-python-2-e-3.html", "title": "Sobre o six e como ele ajuda a escrever c\u00f3digo compat\u00edvel com python 2 e 3"}, {"url": "http://pythonclub.com.br/como_colaborar_com_projetos_open_source.html", "title": "Como colaborar na tradu\u00e7\u00e3o do Djangobook sem conhecer programa\u00e7\u00e3o"}], 10);
});
</script>
<div id="spot-im-root"></div>
<script type="text/javascript">!function(t,o,p){function e(){var t=o.createElement("script");t.type="text/javascript",t.async=!0,t.src=("https:"==o.location.protocol?"https":"http")+":"+p,o.body.appendChild(t)}t.spotId="3de816246c80a51757bb01c5b8c95cda",t.spotName="",t.allowDesktop=!0,t.allowMobile=!1,t.containerId="spot-im-root",e()}(window.SPOTIM={},document,"//www.spot.im/embed/scripts/launcher.js");</script>
</body>
</html>