<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<oembed><type>rich</type><version>1.0</version><provider_name>phorkie</provider_name><provider_url>https://p.cweiske.de/</provider_url><title>CSV generator for hamster timetracker</title><author_name>Christian Weiske</author_name><cache_age>86400</cache_age><width>900</width><height>900</height><html>&lt;!-- embedding all files of https://p.cweiske.de/294 --&gt;
&lt;link rel="stylesheet" href="https://p.cweiske.de/css/embed.css"/&gt;
&lt;div class="phork" id="294"&gt;
    &lt;div class="phork-file"&gt;
 &lt;div class="phork-content"&gt;
  &lt;style type="text/css"&gt;/**
 * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann
 * (http://qbnz.com/highlighter/ and http://geshi.org/)
 */
.php .de1, .php .de2 {font: normal normal 1em/1.2em monospace; margin:0; padding:0; background:none; vertical-align:top;}
.php  {font-family:monospace;}
.php .imp {font-weight: bold; color: red;}
.php li, .php .li1 {color: #DDD;}
.php .ln {width:1px;text-align:right;margin:0;padding:0 2px;vertical-align:top;}
.php .kw1 {color: #b1b100;}
.php .kw2 {color: #000000; font-weight: bold;}
.php .kw3 {color: #990000;}
.php .kw4 {color: #009900; font-weight: bold;}
.php .co1 {color: #666666; font-style: italic;}
.php .co2 {color: #666666; font-style: italic;}
.php .co3 {color: #0000cc; font-style: italic;}
.php .co4 {color: #009933; font-style: italic;}
.php .coMULTI {color: #666666; font-style: italic;}
.php .es0 {color: #000099; font-weight: bold;}
.php .es1 {color: #000099; font-weight: bold;}
.php .es2 {color: #660099; font-weight: bold;}
.php .es3 {color: #660099; font-weight: bold;}
.php .es4 {color: #006699; font-weight: bold;}
.php .es5 {color: #006699; font-weight: bold; font-style: italic;}
.php .es6 {color: #009933; font-weight: bold;}
.php .es_h {color: #000099; font-weight: bold;}
.php .br0 {color: #009900;}
.php .sy0 {color: #339933;}
.php .sy1 {color: #000000; font-weight: bold;}
.php .st0 {color: #0000ff;}
.php .st_h {color: #0000ff;}
.php .nu0 {color: #cc66cc;}
.php .nu8 {color: #208080;}
.php .nu12 {color: #208080;}
.php .nu19 {color:#800080;}
.php .me1 {color: #004000;}
.php .me2 {color: #004000;}
.php .re0 {color: #000088;}
.php span.xtra { display:block; }
&lt;/style&gt;&lt;div class="code"&gt;&lt;table class="php"&gt;&lt;tbody&gt;&lt;tr class="li1"&gt;&lt;td class="ln"&gt;&lt;pre class="de1"&gt;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
&lt;/pre&gt;&lt;/td&gt;&lt;td class="de1"&gt;&lt;pre class="de1"&gt;#!/usr/bin/env php
&lt;span class="kw2"&gt;&amp;lt;?php&lt;/span&gt;
&lt;span class="co4"&gt;/**&lt;/span&gt;
&lt;span class="co4"&gt;&amp;#160;* Generate a CSV file from the hamster timetracker database.&lt;/span&gt;
&lt;span class="co4"&gt;&amp;#160;* Output is only two columns: date and hours worked that day.&lt;/span&gt;
&lt;span class="co4"&gt;&amp;#160;*&lt;/span&gt;
&lt;span class="co4"&gt;&amp;#160;* Works with hamster 2.91.3&lt;/span&gt;
&lt;span class="co4"&gt;&amp;#160;*/&lt;/span&gt;
&lt;span class="re0"&gt;$dbfile&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;a href="http://www.php.net/getenv"&gt;&lt;span class="kw3"&gt;getenv&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="st_h"&gt;'HOME'&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st_h"&gt;'/.local/share/hamster-applet/hamster.db'&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="kw1"&gt;if&lt;/span&gt; &lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="sy0"&gt;!&lt;/span&gt;&lt;a href="http://www.php.net/is_readable"&gt;&lt;span class="kw3"&gt;is_readable&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$dbfile&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="br0"&gt;&amp;#123;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="kw1"&gt;echo&lt;/span&gt; &lt;span class="st0"&gt;&amp;quot;Database file does not exist&lt;span class="es1"&gt;\n&lt;/span&gt;&amp;quot;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="kw1"&gt;echo&lt;/span&gt; &lt;span class="re0"&gt;$dbfile&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st0"&gt;&amp;quot;&lt;span class="es1"&gt;\n&lt;/span&gt;&amp;quot;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;a href="http://www.php.net/exit"&gt;&lt;span class="kw3"&gt;exit&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="nu0"&gt;1&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="br0"&gt;&amp;#125;&lt;/span&gt;
&amp;#160;
&lt;span class="re0"&gt;$db&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="kw2"&gt;new&lt;/span&gt; PDO&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="st_h"&gt;'sqlite:'&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="re0"&gt;$dbfile&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="re0"&gt;$db&lt;/span&gt;&lt;span class="sy0"&gt;-&amp;gt;&lt;/span&gt;&lt;span class="me1"&gt;setAttribute&lt;/span&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;PDO&lt;span class="sy0"&gt;::&lt;/span&gt;&lt;span class="me2"&gt;ATTR_ERRMODE&lt;/span&gt;&lt;span class="sy0"&gt;,&lt;/span&gt; PDO&lt;span class="sy0"&gt;::&lt;/span&gt;&lt;span class="me2"&gt;ERRMODE_EXCEPTION&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160;
&lt;span class="re0"&gt;$stmt&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="re0"&gt;$db&lt;/span&gt;&lt;span class="sy0"&gt;-&amp;gt;&lt;/span&gt;&lt;span class="me1"&gt;query&lt;/span&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="st_h"&gt;'SELECT start_time, end_time'&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st_h"&gt;' FROM facts'&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="co1"&gt;//. ' JOIN activities ON facts.activity_id = activities.id'&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="co1"&gt;//. ' JOIN categories ON activities.category_id = categories.id'&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st_h"&gt;' ORDER BY facts.start_time'&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="co1"&gt;//. ' LIMIT 10'&lt;/span&gt;
&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160;
&lt;span class="kw1"&gt;echo&lt;/span&gt; &lt;span class="st0"&gt;&amp;quot;date;sum&lt;span class="es1"&gt;\n&lt;/span&gt;&amp;quot;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160;
&lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="kw4"&gt;null&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="re0"&gt;$lastSum&lt;/span&gt; &amp;#160;&lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="nu0"&gt;0&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="kw1"&gt;while&lt;/span&gt; &lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$row&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="re0"&gt;$stmt&lt;/span&gt;&lt;span class="sy0"&gt;-&amp;gt;&lt;/span&gt;&lt;span class="me1"&gt;fetch&lt;/span&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;PDO&lt;span class="sy0"&gt;::&lt;/span&gt;&lt;span class="me2"&gt;FETCH_ASSOC&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="br0"&gt;&amp;#123;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="re0"&gt;$date&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;a href="http://www.php.net/substr"&gt;&lt;span class="kw3"&gt;substr&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$row&lt;/span&gt;&lt;span class="br0"&gt;&amp;#91;&lt;/span&gt;&lt;span class="st_h"&gt;'start_time'&lt;/span&gt;&lt;span class="br0"&gt;&amp;#93;&lt;/span&gt;&lt;span class="sy0"&gt;,&lt;/span&gt; &lt;span class="nu0"&gt;0&lt;/span&gt;&lt;span class="sy0"&gt;,&lt;/span&gt; &lt;span class="nu0"&gt;10&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="kw1"&gt;if&lt;/span&gt; &lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$date&lt;/span&gt; &lt;span class="sy0"&gt;!=&lt;/span&gt; &lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;&amp;amp;&amp;amp;&lt;/span&gt; &lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;!==&lt;/span&gt; &lt;span class="kw4"&gt;null&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="br0"&gt;&amp;#123;&lt;/span&gt;
&amp;#160; &amp;#160; &amp;#160; &amp;#160; &lt;span class="kw1"&gt;echo&lt;/span&gt; &lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st_h"&gt;';'&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;a href="http://www.php.net/gmdate"&gt;&lt;span class="kw3"&gt;gmdate&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="st_h"&gt;'H:i:s'&lt;/span&gt;&lt;span class="sy0"&gt;,&lt;/span&gt; &lt;span class="re0"&gt;$lastSum&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st0"&gt;&amp;quot;&lt;span class="es1"&gt;\n&lt;/span&gt;&amp;quot;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160; &amp;#160; &amp;#160; &amp;#160; &lt;span class="re0"&gt;$lastSum&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="nu0"&gt;0&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="br0"&gt;&amp;#125;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="re0"&gt;$lastSum&lt;/span&gt; &lt;span class="sy0"&gt;+=&lt;/span&gt; &lt;a href="http://www.php.net/strtotime"&gt;&lt;span class="kw3"&gt;strtotime&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$row&lt;/span&gt;&lt;span class="br0"&gt;&amp;#91;&lt;/span&gt;&lt;span class="st_h"&gt;'end_time'&lt;/span&gt;&lt;span class="br0"&gt;&amp;#93;&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="sy0"&gt;-&lt;/span&gt; &lt;a href="http://www.php.net/strtotime"&gt;&lt;span class="kw3"&gt;strtotime&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$row&lt;/span&gt;&lt;span class="br0"&gt;&amp;#91;&lt;/span&gt;&lt;span class="st_h"&gt;'start_time'&lt;/span&gt;&lt;span class="br0"&gt;&amp;#93;&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;=&lt;/span&gt; &lt;span class="re0"&gt;$date&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="br0"&gt;&amp;#125;&lt;/span&gt;
&lt;span class="kw1"&gt;if&lt;/span&gt; &lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;!==&lt;/span&gt; &lt;span class="kw4"&gt;null&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="br0"&gt;&amp;#123;&lt;/span&gt;
&amp;#160; &amp;#160; &lt;span class="kw1"&gt;echo&lt;/span&gt; &lt;span class="re0"&gt;$lastDate&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st_h"&gt;';'&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;a href="http://www.php.net/gmdate"&gt;&lt;span class="kw3"&gt;gmdate&lt;/span&gt;&lt;/a&gt;&lt;span class="br0"&gt;&amp;#40;&lt;/span&gt;&lt;span class="st_h"&gt;'H:i:s'&lt;/span&gt;&lt;span class="sy0"&gt;,&lt;/span&gt; &lt;span class="re0"&gt;$lastSum&lt;/span&gt;&lt;span class="br0"&gt;&amp;#41;&lt;/span&gt; &lt;span class="sy0"&gt;.&lt;/span&gt; &lt;span class="st0"&gt;&amp;quot;&lt;span class="es1"&gt;\n&lt;/span&gt;&amp;quot;&lt;/span&gt;&lt;span class="sy0"&gt;;&lt;/span&gt;
&lt;span class="br0"&gt;&amp;#125;&lt;/span&gt;
&lt;span class="sy1"&gt;?&amp;gt;&lt;/span&gt;
&amp;#160;&lt;/pre&gt;&lt;/td&gt;&lt;/tr&gt;&lt;/tbody&gt;&lt;/table&gt;&lt;/div&gt;
 &lt;/div&gt;
 &lt;div class="phork-meta"&gt;
  &lt;a href="https://p.cweiske.de/294/rev-raw/5686c8ae1c1160d74686990e9e97efab269aa640/hamstercsv.php" style="float: right"&gt;view raw source&lt;/a&gt;
  &lt;a href="https://p.cweiske.de/294#hamstercsv.php"&gt;hamstercsv.php&lt;/a&gt;
 &lt;/div&gt;
&lt;/div&gt;
&lt;/div&gt;
</html></oembed>
