<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Stavelin.com &#187; kode</title>
	<atom:link href="http://stavelin.com/blog/category/nerding/kode/feed/" rel="self" type="application/rss+xml" />
	<link>http://stavelin.com/blog</link>
	<description>digital lekeplass</description>
	<lastBuildDate>Tue, 15 May 2012 10:19:15 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>lxml for python 2.7 på osx</title>
		<link>http://stavelin.com/blog/2012/05/15/lxml-for-python-2-7-pa-osx/</link>
		<comments>http://stavelin.com/blog/2012/05/15/lxml-for-python-2-7-pa-osx/#comments</comments>
		<pubDate>Tue, 15 May 2012 10:19:15 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[lxml]]></category>
		<category><![CDATA[osx]]></category>
		<category><![CDATA[python]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=1196</guid>
		<description><![CDATA[easy_install-2.7 lxml ikke easy_install lxml Dette er mest et notat til megselv, kanskje jeg husker det til neste gang selv nå.]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=1196"><!-- &nbsp; --></abbr>
<p><code>easy_install-2.7 lxml</code><br />
ikke<br />
<code>easy_install lxml</code></p>
<p>Dette er mest et notat til megselv, kanskje jeg husker det til neste gang selv nå.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2012/05/15/lxml-for-python-2-7-pa-osx/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Spillanmeldere &#8211; kritiker eller entusiast? Eller begge?</title>
		<link>http://stavelin.com/blog/2012/03/07/spillanmeldere-kritiker-eller-entusiast-eller-begge/</link>
		<comments>http://stavelin.com/blog/2012/03/07/spillanmeldere-kritiker-eller-entusiast-eller-begge/#comments</comments>
		<pubDate>Wed, 07 Mar 2012 15:20:33 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[Media]]></category>
		<category><![CDATA[Nerding]]></category>
		<category><![CDATA[Nye medier]]></category>
		<category><![CDATA[metode]]></category>
		<category><![CDATA[nrk]]></category>
		<category><![CDATA[p3]]></category>
		<category><![CDATA[scraperwiki]]></category>
		<category><![CDATA[Spill]]></category>
		<category><![CDATA[spillanmeldelse]]></category>
		<category><![CDATA[terningkast]]></category>
		<category><![CDATA[webscraping]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=1197</guid>
		<description><![CDATA[Webscraping anser jeg som et metodisk verktøy som burde brukes mer. Ikke fordi det er den beste måten å gjøre ting på, lagt der i fra, men fordi det er enkelt, nyttig og relativt raskt. Et verktøy for scraping jeg har lekt med er scraperwiki. Ikke bare kan du lage scrapers (skrapere?) med scraperwiki, du [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=1197"><!-- &nbsp; --></abbr>
<p>Webscraping anser jeg som et metodisk verktøy som burde brukes mer. Ikke fordi det er den beste måten å gjøre ting på, lagt der i fra, men fordi det er enkelt, nyttig og relativt raskt. Et verktøy for scraping jeg har lekt med er <a href="https://scraperwiki.com">scraperwiki</a>. </p>
<p>Ikke bare kan du lage scrapers (skrapere?) med scraperwiki, du kan også lage views (presentasjonslag). Etter litt leking kom jeg fram til dette:</p>
<div><iframe width="100%" height="400px" src="https://views.scraperwiki.com/run/testview_6/"></iframe></div>
<p>NRK P3s spillanmeldelser bruker 3 av 6 terningsider til 75% av sine anmeldelser. De har kun brukt terningkast 1 én eneste gang, og da til å feilkategorisere en film. Hva betyr det?</p>
<p>Betyr det at spill, som en relativt ny kulturform, trenger evangelister og entusiaster til å pushe spillets utmerkede egenskaper på oss? Anmelder de ikke de dårlige spillene? (jeg har selv spilt flere spill jeg kunne gitt terningkast 1 og 2 de siste årene, skriver ikke P3 om disse?) Har spillanmeldere noen insentiv for å vurdere "snilt"? Eller har de lave forventninger? </p>
<p>Tja, jeg som gjorde dette av metodisk interesse får vel innse at kvantitative mål ikke besvarer disse spørsmålene, men; det viser at terningkast ikke hverken er normalfordelt eller jevnt distribuert. </p>
<p>.. kanskje jeg får en jevn distribusjon hvis jeg gjør dette på popmusikk eller amerikanske filmer? </p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2012/03/07/spillanmeldere-kritiker-eller-entusiast-eller-begge/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Skattelister slik du aldri har sett dem før</title>
		<link>http://stavelin.com/blog/2012/02/20/skattelister-slik-du-aldri-har-sett-dem-for/</link>
		<comments>http://stavelin.com/blog/2012/02/20/skattelister-slik-du-aldri-har-sett-dem-for/#comments</comments>
		<pubDate>Mon, 20 Feb 2012 10:11:46 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[Design]]></category>
		<category><![CDATA[kode]]></category>
		<category><![CDATA[Kuriosa]]></category>
		<category><![CDATA[Deluge]]></category>
		<category><![CDATA[even westvang]]></category>
		<category><![CDATA[skattelister]]></category>
		<category><![CDATA[visualisering]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=1174</guid>
		<description><![CDATA[Hvordan skattelistene i Norge har blitt brukt har rettvis blir kritisert. Det betyr ikke at offentlige skattelister er noen dårlig idé, det betyr bare at de ideene som ble tatt i bruk i liten grad fulgte intensjonene om et åpent samfunn. Even Westvang i Bengler har en helt annen idé, og viser oss noe du [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=1174"><!-- &nbsp; --></abbr>
<p>Hvordan skattelistene i Norge har blitt brukt har rettvis blir kritisert. Det betyr ikke at offentlige skattelister er noen dårlig idé, det betyr bare at de ideene som ble tatt i bruk i liten grad fulgte intensjonene om et åpent samfunn. <a href="http://vimeo.com/bengler">Even Westvang i Bengler</a> har en helt annen idé, og viser oss noe du neppe har sett før på denne måten: ved å se sjekkeskattelistene mellom to år viser prosjektet hvordan folk flytter rundt i Norge. Det må da sies å både værer vakrere og nyttigere enn å vite hvilken kjendis som har høyest inntekt?<br />
<iframe src="http://player.vimeo.com/video/36154005" width="510" height="287" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe></p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2012/02/20/skattelister-slik-du-aldri-har-sett-dem-for/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Firebug bundle for TextMate</title>
		<link>http://stavelin.com/blog/2011/01/16/firebug-bundle-for-textmate/</link>
		<comments>http://stavelin.com/blog/2011/01/16/firebug-bundle-for-textmate/#comments</comments>
		<pubDate>Sun, 16 Jan 2011 13:43:32 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[debugging]]></category>
		<category><![CDATA[firebug]]></category>
		<category><![CDATA[firefox]]></category>
		<category><![CDATA[javascript]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=1007</guid>
		<description><![CDATA[Debugging av javascript i firebug gjør avlusing til en langt mer oversiktlig og ryddig affære. Å benytte en liten leksehjelp som denne bundlen hjelper deg videre fra alert() og console.log(), som fort blir tungvindt i lengden. Få alle console-funksjonene rett i handa med Firebug bundle for TextMate. Last ned .dmg-filen, åpne og dobbeltklikk. Ferdig arbeid.. [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=1007"><!-- &nbsp; --></abbr>
<p>Debugging av javascript i firebug gjør avlusing til en langt mer oversiktlig og ryddig affære. Å benytte en liten leksehjelp som denne bundlen hjelper deg videre fra alert() og console.log(), som fort blir tungvindt i lengden.<br />
<img src="http://stavelin.com/blog/wp-content/bilder/firebundle-1.png" alt="Få alle console-funksjonene rett i handa med Firebug bundle for TextMate" class="" /></p>
<p class="bildetekst">Få alle console-funksjonene rett i handa med Firebug bundle for TextMate.</p>
<p><a href="http://doctyper.com/downloads/Firebug.tmbundle.dmg"><img src="http://stavelin.com/blog/wp-content/bilder/firebundle-2.png" alt="Last ned .dmg-filen, åpne og dobbeltklikk. Ferdig arbeid." class="" /></a></p>
<p class="bildetekst">Last ned .dmg-filen, åpne og dobbeltklikk. Ferdig arbeid..</p>
<p>Åpne menyen i TextMate med <em>cmd + D</em></p>
<p>Via <a href="http://doctyper.com/archives/200703/firebug-bundle-for-textmate/">doctyper.com</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2011/01/16/firebug-bundle-for-textmate/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Gratis kropp &#8211; dyr sjel</title>
		<link>http://stavelin.com/blog/2010/11/18/gratis-kropp-dyr-sjel/</link>
		<comments>http://stavelin.com/blog/2010/11/18/gratis-kropp-dyr-sjel/#comments</comments>
		<pubDate>Thu, 18 Nov 2010 11:45:43 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[Studentliv]]></category>
		<category><![CDATA[commentspace]]></category>
		<category><![CDATA[iTunesU]]></category>
		<category><![CDATA[mit]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=989</guid>
		<description><![CDATA[Har du lyst til å studere på MIT? Jeg óg. I følge denne diskutable (i den mest positive forstand) grafen skårer MIT best på ROI over 30 år. Samtidig koster det flesk. Å studere på MIT koster flesk, men betaler seg tydeligvis i lengden. Det virkelig kule er at en del innhold fra utdanningen ved [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=989"><!-- &nbsp; --></abbr>
<p>Har du lyst til å studere på MIT? Jeg óg.</p>
<p>I følge <a href="http://www.commentspace.net/commentspace/?vis=http://www.commentspace.net/media/swf/CollegeROIVis.swf&showLinks=false&workspace=CollegeROI">denne diskutable</a> (i den mest positive forstand) grafen skårer MIT best på ROI over 30 år. Samtidig koster det flesk.<br />
<img src="http://stavelin.com/blog/wp-content/bilder/mit_roi.png" alt="MIT ROI" class="" /></p>
<p class="bildetekst">Å studere på MIT koster flesk, men betaler seg tydeligvis i lengden.</p>
<p>Det virkelig kule er at en del innhold fra utdanningen ved MIT er tilgjengelig på nett. Via MIT OpenCourseWare er fag som "Introduction to Computer Science and Programming" tilgjengelig for alle. Det er faktisk like kult som at bøker er gratis tilgjengelig i offentlige bibliotek. Bare bedre.</p>
<p>På <a href="http://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-00-introduction-to-computer-science-and-programming-fall-2008/video-lectures/">denne nettsiden</a> er videoer av alle forelesningene tilgjengelige. Og om du er en eplefantast eller ellers har iTunes kan du laste det samme ned via <a href="http://www.apple.com/education/itunes-u/">iTunesU</a>. </p>
<p>Så innholdet, - kunnskapen kan tilegnes gratis. Med hjelp av MITs forelesere på video. Vitnemålet, nettverket og opplevelsen derimot; det forblir for de få.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2010/11/18/gratis-kropp-dyr-sjel/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Utvide django admin</title>
		<link>http://stavelin.com/blog/2010/10/14/utvide-django-admin/</link>
		<comments>http://stavelin.com/blog/2010/10/14/utvide-django-admin/#comments</comments>
		<pubDate>Thu, 14 Oct 2010 13:32:59 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[django]]></category>
		<category><![CDATA[django-admin]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=959</guid>
		<description><![CDATA[Alt i django er mer eller mindre tilgjengelig for å utvides. Koden er åpen, og den som vil knote seg fram til nye løsninger kan bare sette i gang. I denne posten viser jeg hvordan du får tak i verdier fra fra dine modeller fra admin-panelet via change_form.html Fordelen med rammeverk er selvsagt at noen [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=959"><!-- &nbsp; --></abbr>
<p>Alt i django er mer eller mindre tilgjengelig for å utvides. Koden er åpen, og den som vil knote seg fram til nye løsninger kan bare sette i gang. I denne posten viser jeg hvordan du får tak i verdier fra fra dine modeller fra admin-panelet via change_form.html</p>
<p>Fordelen med rammeverk er selvsagt at noen allerede har tenkt på det aller meste fra før, ulempen er at du ikke vet hva de tenkte da de skreiv koden. Det meste er vell dokumentert et-eller-annet sted, men hvor skal du begynne å leite? Google, så klart, men hvilke søke-termer?</p>
<p>Min klasse i models.py har mange verdier, som dermed er representert med samme kolonne-navn i databasen. Men hvordan henter jeg disse enkeltvis ut når jeg skal redigere objektet fra admin-panelet? Hva heter objektet?<br />
<span style="color: #00ccff;">{{ obj.verdi }}</span>, <span style="color: #00ccff;">{{ object.verdi }}</span> ?</p>
<p>Hvordan skal man gjette slikt?</p>
<p>Vell, det heter<span style="color: #00ccff;"> {{ <strong>original</strong>.verdi }}</span>.<br />
Dette er sakset ut fra min nå redigerte /templates/admin/appname/app/change_form.html (eksempler på appname og app: flatpages/flatpage)</p>
<pre>
{% block form_top %}
{% if original.url  and original.organization != 'nytimes.com' %}
< iframe src ="{{ original.url }}" width="100%" height="500"></ iframe>
{% endif %}
</pre>
<p>Ja, jeg vill ha en iframe som viser nettsiden som er laget, men ikke hvis den ligger hos nytimes.com, for de videresender panelet mitt til sin artikkel.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2010/10/14/utvide-django-admin/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Nye greier på python-stien</title>
		<link>http://stavelin.com/blog/2010/06/01/nye-greier-pa-python-stien/</link>
		<comments>http://stavelin.com/blog/2010/06/01/nye-greier-pa-python-stien/#comments</comments>
		<pubDate>Tue, 01 Jun 2010 13:21:43 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[freeBSD]]></category>
		<category><![CDATA[python]]></category>
		<category><![CDATA[python path]]></category>
		<category><![CDATA[server]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=879</guid>
		<description><![CDATA[Jeg krangler tidvis med python på sen server som kjører freeBSD, som jeg leier hos subsys.no. Hovedpoenget med prosjektet er å lære django og python for mer effektiv webutvikling/prototyping. Å lære ny teknologi handler ofte, for min del i alle fall, om å sitte fast før jeg får med meg hvordan ting fungerer. Denne posten [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=879"><!-- &nbsp; --></abbr>
<p>Jeg krangler tidvis med python på sen server som kjører freeBSD, som jeg leier hos subsys.no. Hovedpoenget med prosjektet er å lære django og python for mer effektiv webutvikling/prototyping. Å lære ny teknologi handler ofte, for min del i alle fall, om å sitte fast før jeg får med meg hvordan ting fungerer. Denne posten inneholder info om hvordan legge til foldere på python-stien, slik at importering med "from module import stuff" fungerer. Grunnen til at jeg blogger dette er at jeg glemmer det mellom hver gang det er nyttig, og derfor fint å ha tilgjengelig på nett, for meg og kanskje deg.</p>
<p>I roten på webhotellet mitt (og ditt) ligger det en usynlig fil som heter .bash_profile. Den kan hete andre ting som .bashrc, men i mitt tilfelle altså .bash_profile. Denne kan redigeres med nano, eller andre terminal-baserte editorer.</p>
<pre class="bash">$ nano .bash_profile</pre>
<p>Legg til en ny sti:</p>
<pre>export PYTHONPATH=/home/users/dittbrukernavn/mappen_du_vil_adde:$PYTHONPATH</pre>
<p>Lagre (ctrl + o i nano).</p>
<p>Du må logge ut og inn igjen via ssh for at dette skal tre i kraft. </p>
<p>For å teste om ting virket kan du printe ut sys.path'n i python:</p>
<pre>
$ python
Python 2.6.5 (r265:79063, May 21 2010, 00:49:11)
[GCC 4.2.1 20070719  [FreeBSD]] on freebsd7
Type "help", "copyright", "credits" or "license" for more information.
>>> import sys
>>> sys.path</pre>
<p>det du får ut på skjermen er da en liste over foldere som er på python-stien:<br />
['', '/usr/local/lib/python2.6/site-packages/setuptools-0.6c11-py2.6.egg', '/usr/local/lib/python2.6/site-packages/pytz-2010h-py2.6.egg', '/usr/local/lib/python2.6/site-packages/Pygments-1.3.1-py2.6.egg', '/usr/local/lib/python2.6/site-packages/boto-1.9b-py2.6.egg', '/usr/local/lib/python2.6/site-packages/lxml-2.2.4-py2.6-freebsd-7.3-RELEASE-amd64.egg', '/usr/local/lib/python2.6/site-packages/simplejson-2.1.1-py2.6-freebsd-7.3-RELEASE-amd64.egg', '/usr/local/lib/python2.6/site-packages/Genshi-0.6-py2.6.egg', '/usr/local/lib/python2.6/site-packages/flup-1.0.2-py2.6.egg', '/home/users/<strong>dittbrukernavn/mappen_du_vil_adde</strong>', '/usr/local/lib/python26.zip', '/usr/local/lib/python2.6', '/usr/local/lib/python2.6/plat-freebsd7', '/usr/local/lib/python2.6/lib-tk', '/usr/local/lib/python2.6/lib-old', '/usr/local/lib/python2.6/lib-dynload', '/usr/local/lib/python2.6/site-packages', '/usr/local/lib/python2.6/site-packages/PIL']</p>
<p>Hvori den nye forhåpentligvis er å finne.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2010/06/01/nye-greier-pa-python-stien/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Lage indexer i mysql med MAMP</title>
		<link>http://stavelin.com/blog/2010/04/08/lage-indexer-i-mysql-med-mamp/</link>
		<comments>http://stavelin.com/blog/2010/04/08/lage-indexer-i-mysql-med-mamp/#comments</comments>
		<pubDate>Thu, 08 Apr 2010 09:54:37 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[Nerding]]></category>
		<category><![CDATA[databaser]]></category>
		<category><![CDATA[mamp]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[osx]]></category>
		<category><![CDATA[sql]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=849</guid>
		<description><![CDATA[Jeg har ikke funnet noen måte å lager indexer på i Sequel Pro, og med det har jeg alternativet klart; i terminalen. Antagelsen er at mysql kjører i MAMP på OSX (10.5.8). Åpne terminalen. Skriv inn /Applications/MAMP/Library/bin/mysql -uroot -p kvitter med root-passordet som ut-av-boksen er root. Velg en database: mysql&#62; USE tabellnavn; Vis tabellene i [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=849"><!-- &nbsp; --></abbr>
<p>Jeg har ikke funnet noen måte å lager indexer på i <a href="http://stavelin.com/blog/2010/03/28/sequel-pro-avloser-cocoamysql/">Sequel Pro</a>, og med det har jeg alternativet klart; i terminalen.</p>
<p>Antagelsen er at <a href="www.mysql.com/">mysql</a> kjører i <a href="www.mamp.info/">MAMP</a> på OSX (10.5.8).</p>
<p>Åpne terminalen.<br />
Skriv inn</p>
<pre class="bash">/Applications/MAMP/Library/bin/mysql -uroot -p</pre>
<p>kvitter med root-passordet som ut-av-boksen er <em>root</em>.</p>
<p>Velg en database:</p>
<pre class="mysql">mysql&gt; <span style="color: #993333; font-weight: bold;">USE</span> tabellnavn;</pre>
<p>Vis tabellene i databasen (fint å vite hva som finnes):</p>
<pre class="mysql">mysql&gt; <span style="color: #993333; font-weight: bold;">SHOW</span> tables;</pre>
<p>Sjekk om tabellen har en index:</p>
<pre class="mysql">mysql&gt; <span style="color: #993333; font-weight: bold;">SHOW</span> indexes <span style="color: #993333; font-weight: bold;">FROM</span> 2009analyse_int;</pre>
<p>Lag en index</p>
<pre class="mysql">mysql&gt; <span style="color: #993333; font-weight: bold;">CREATE INDEX</span> minNye_index ON tabellnavn<span style="color: #66cc66;">&#40;</span>kolonne_du_vil_lage_index_på<span style="color: #66cc66;">&#41;</span>;</pre>
<p>Done.</p>
<p>PS - Note to self: Behovet for indexer dukket for min del opp når jeg skulle hente ut ca 75.000 rader fra en tabell over nettartikler, hvorav noen var duplikater. For å hente ut kun én linje per unike url gjorde jeg følgende spørring:</p>
<pre class="mysql"><span style="color: #993333; font-weight: bold;">SELECT</span> *, COUNT<span style="color: #66cc66;">&#40;</span>unik_id<span style="color: #66cc66;">&#41;</span> AS duplikat
<span style="color: #993333; font-weight: bold;">FROM</span> min_fine_tabell
<span style="color: #993333; font-weight: bold;">GROUP</span> <span style="color: #993333; font-weight: bold;">BY</span> unik_id
<span style="color: #993333; font-weight: bold;">ORDER</span> <span style="color: #993333; font-weight: bold;">BY</span> duplikat DESC;
&nbsp;</pre>
<p>Da kommer duplikatene (med antall større enn 1) øverst, følger alle som er unike.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2010/04/08/lage-indexer-i-mysql-med-mamp/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Sequel Pro avløser CocoaMySQL</title>
		<link>http://stavelin.com/blog/2010/03/28/sequel-pro-avloser-cocoamysql/</link>
		<comments>http://stavelin.com/blog/2010/03/28/sequel-pro-avloser-cocoamysql/#comments</comments>
		<pubDate>Sun, 28 Mar 2010 16:46:55 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[cocoamysql]]></category>
		<category><![CDATA[databaser]]></category>
		<category><![CDATA[dbms]]></category>
		<category><![CDATA[Mac]]></category>
		<category><![CDATA[mamp]]></category>
		<category><![CDATA[mysql]]></category>
		<category><![CDATA[sequel pro]]></category>
		<category><![CDATA[sql]]></category>
		<category><![CDATA[sql klient]]></category>
		<category><![CDATA[xamp]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=840</guid>
		<description><![CDATA[CocoaMySQL er en fantastisk liten klient til DBMSet mySQL. For Mac. På tross av at cocoamysql alltid fikk jobben gjort, så ser videreføringen i Sequel Pro ut som et steg opp. Sequel Pro GUI. At CocoaMySQL hverken var fullt av fancy funksjoner eller revolusjonerende teknologier var aldri noe hinder for arbeidsflyten for oss som stort [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=840"><!-- &nbsp; --></abbr>
<p><a href="http://osx.iusethis.com/app/cocoamysql">CocoaMySQL</a> er en fantastisk liten klient til  <abbr title="Database Management System">DBMSet</abbr> <a href="http://www.mysql.com/">mySQL</a>. For Mac. På tross av at cocoamysql alltid fikk jobben gjort, så ser videreføringen i <strong><a href="http://osx.iusethis.com/app/sequelpro">Sequel Pro</a></strong> ut som et steg opp.</p>
<p><img src="http://stavelin.com/blog/wp-content/bilder/squelPro.png" alt="Sequel Pro GUI" class="" /></p>
<p class="bildetekst">Sequel Pro GUI.</p>
<p>At CocoaMySQL hverken var fullt av fancy funksjoner eller revolusjonerende teknologier var aldri noe hinder for arbeidsflyten for oss som stort sett jobber med databaser for web. Sequel Pro følger i samme fotspor. Det er først og fremst <abbr title="Graphical User Interface">GUIet</abbr> som er oppdatert til dagens standard for Mac, så vell som mindre endringer som nærmest likner bugfixer. Personlig er det bare muligheten til å kommentere tabellene som jeg virkelig savnet.
<p class="bildetekst">(som er uendelig nyttig hvis du lagrer verdier av typen verdiskalaer, f.eks. 0 - 10 hvor 10 er admin og tallene nedover beskriver ulike tilgangrettigheter, eller tallskalaer som kategoriserer variabler i et analyseopplegg).</p>
<p>En av de viktigste egenskapene til en SQLklient, er at den er enkel å bruke og sette opp. Typisk kjører jeg en lokal server på laptop'n min, og da stort sett en ferdig pakke ala <a href="http://www.mamp.info/">MAMP</a>. At det tar mindre enn 2 minutter å sette dette opp er målet, og dette viderefører Sequel Pro. Se f.eks. <a href="http://www.sequelpro.com/docs/Connecting_to_MAMP_or_XAMPP">instruksene for MAMP/XAMP her</a>. </p>
<p>Jeg snublet over Sequel Pro da cocoamysql, av en aller annen grunn, tok urimelig mye systemresurser i et stort datasett jeg jobber med. Sequel Pro kjører som det skulle være det neste på skjermen her, noe som er langt fram sannheten. At små detaljer som redigering av innhold i celler, reorganisering av tabellstrukturer og bedre håndtering av tabellenes metadata er betydelig smoothere enn før gjør opplevelsen sammenliknbar med forgjengeren, men samtidig et skritt opp. Jobber du med mysqldatabaser på mac, så er Sequel Pro absolutt verdt å ta en titt på. Open source er det også. </p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2010/03/28/sequel-pro-avloser-cocoamysql/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Cron-jobber</title>
		<link>http://stavelin.com/blog/2010/02/09/cron-jobber/</link>
		<comments>http://stavelin.com/blog/2010/02/09/cron-jobber/#comments</comments>
		<pubDate>Tue, 09 Feb 2010 17:19:16 +0000</pubDate>
		<dc:creator>Eirik</dc:creator>
				<category><![CDATA[kode]]></category>
		<category><![CDATA[Web]]></category>
		<category><![CDATA[cron-jobber]]></category>
		<category><![CDATA[cronjob]]></category>
		<category><![CDATA[crontab]]></category>
		<category><![CDATA[subsys.no]]></category>

		<guid isPermaLink="false">http://stavelin.com/blog/?p=805</guid>
		<description><![CDATA[- Resultater etter prøv og feil metoden. Å kjøre cron-jobber er et spennende skritt videre fra å kun scripte for kode som trigges av brukeres aktivitet. Med cron-jobber kan prosesser kjøres automatisk på tidspunkt etter dine preferanser. For orden skyld; jeg har har et webhotell hos subsys.no. Cronjobber er en tjeneste som sjeldent kommer som [...]]]></description>
			<content:encoded><![CDATA[<abbr class="unapi-id" title="http://stavelin.com/blog/?p=805"><!-- &nbsp; --></abbr>
<p>- Resultater etter prøv og feil metoden.<br />
Å kjøre <a href="http://en.wikipedia.org/wiki/Cron">cron-jobber</a> er et spennende skritt videre fra å kun scripte for kode som trigges av brukeres aktivitet. Med cron-jobber kan prosesser kjøres automatisk på tidspunkt etter dine preferanser. </p>
<div style="width:200px;margin:5px; padding:5px; float:right;border-left:1px dashed gray;"><b>For orden skyld</b>;<br /> jeg har har et webhotell hos subsys.no. Cronjobber er en tjeneste som sjeldent kommer som standard hos webhotelltilbydere.</div>
<p>Å sette opp cronjobber fordrer at du kan logge deg inn på serveren via kommandolinjen (SSH), og videre redigere innstillingene for oppsettet i terminalen. For meg var det ikke intuitivt hvordan dette skulle gjøres i praksis, så her er hvordan jeg gjorde det hos subsys.</p>
<p>Koble til med SSH.</p>
<pre class="bash"><span style="color: #c20cb9; font-weight: bold;">ssh</span> -L <span style="color: #000000;">8888</span>:server10.subsys.no:<span style="color: #000000;">3306</span> brukernavn@server10.subsys.no</pre>
<p>Kvitter med passord.</p>
<p>Så skriver du inn crontab -e</p>
<pre class="bash"><span style="color: #7a0874; font-weight: bold;">&#91;</span>brukernavn@server10 ~/mevi<span style="color: #7a0874; font-weight: bold;">&#93;</span>$ crontab -e</pre>
<p><strong>-e</strong> står for "edit", du kan lese mer om <a href="http://www.opengroup.org/onlinepubs/9699919799/utilities/crontab.html">handlingsrommet ditt her</a>.</p>
<p>Hos subsys.no kjører de freeBSD, og der åpnes contab-filen i en "editor" i terminalen, denne heter nano(?). Du kan skrive inn tekst i filen (som er helt blank i utgangspunktet og som ikke vises/finnes via en ftp-klient), lagre, bla, osv. Hva du kan gjøre listes under det som i første omgang er en helt hvit terminal.</p>
<p>Rediger filen etter mønsteret "alle" guider for crontab gir, du kan f.eks. ta <a href="http://en.wikipedia.org/wiki/Cron#Operators">wikipedias tekst om saken som utgangspunkt</a>.</p>
<p><img src="http://stavelin.com/blog/wp-content/bilder/Terminal_ssh_crontab.png" alt="$HOME fungerer fint i stede for å skrive inn hele adressen som er noe slikt som home users  brukernavn" class="" /></p>
<p class="bildetekst">$HOME fungerer fint i stede for å skrive inn hele adressen som er noe slikt som /home/users/brukernavn/.</p>
<p>Her er et eksempel på mine redigeringer:<br />
<code><br />
MAILTO=gjett@stavelin.com<br />
30 * * * * $HOME/pythonscript/python.py<br />
0 0 * * * $HOME/phpscript/phpfil.php<br />
</code></p>
<p>MAILTO er en glimrende sak som sender deg en rapport på mail hver gang oppgaven utføres. Den er særlig nyttig når du setter dette opp for første gang, for å sjekke at ting fungerer som det skal, event hva som ikke fungerer.</p>
<p>Den første oppgaven jeg satt opp var å kjøre et pythonscript. Husk</p>
<pre class="python"><span style="color: #808080; font-style: italic;">#!/usr/local/bin/pytho</span></pre>
<p>i starten av filen, slik at scriptet vil kjøre. Husk også å sette rettighetene på filen slik at den blir kjørbar (executable), med </p>
<pre class="bash"><span style="color: #c20cb9; font-weight: bold;">chmod</span> +x filnavn.py</pre>
<p>Slike ting avslører feilmeldingene som jeg fikk på mail fram MAILTO-biten.</p>
<p>Når det kommer til tidsaspektene hvor når disse kommandoene skal gå av, så finner du også mye dokumentasjon rundt om. Selv hadde jeg en hvis glede av denne <a href="http://www.htmlbasix.com/crontab.shtml">crontab kalkulatoren</a>. Kodene jeg bruker i eksemplet over leser du slik:<br />
30 * * * * betyr det 30. minuttet, hver time, hver dag, hver måned, alle ukedager. aka hver eneste time, 30 minutter over hel. Altså 24 jobber i døgnet.<br />
0 0 * * * betyr det 0. minuttet, den 0. timen hver dag, hver måned, alle ukedager. aka første minutt den første timen i døgnet. Altså ved midnatt hvert døgn.</p>
<p>Håper dette er nyttig for noen, det hadde vært det for meg for noen dager siden.</p>
]]></content:encoded>
			<wfw:commentRss>http://stavelin.com/blog/2010/02/09/cron-jobber/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
	</channel>
</rss>

