Meeskond "Vennaskond": Difference between revisions

From ICO wiki
Jump to navigationJump to search
No edit summary
Line 4: Line 4:
* Mart Mägi
* Mart Mägi
* Riho Kukk
* Riho Kukk
==Meeskond==
* Kristjan Roosild
* Ragnar Rattas
* Holger Rünkaru


==XML==
==XML==
Line 10: Line 16:


===XML===
===XML===
XML fail sisaldab andmeid
XML fail sisaldab andmeid [http://metaweb.stat.ee/classificator_publish_list.htm Eesti haldus- ja asustusüksuste] (EHAK) kohta. Andmed saadi [http://metaweb.stat.ee/get_classificator_file.htm?id=3279007&siteLanguage=ee siit].
Statistikaametil on küll juba olemas [http://metaweb.stat.ee/get_classificator_file.htm?id=3273742&siteLanguage=ee EHAKi xml], kuid see ei ole just kõige paremini loetav, sellepärast proovisimegi ise parema teha.
 
[https://ehak.codeplex.com/SourceControl/changeset/view/16692#260910 Link codeplexis olevale xml-ile] (see on liiga suur siia panekuks).


===XML schema (XSD)===
<source lang="xml">
<source lang="xml">
<?xml version="1.0" encoding="utf-8"?>
<?xml version="1.0" encoding="utf-8"?>
<Autoralli>
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <Võistlussari id="2012wrc" aasta="2012">
  <xs:element name="ehak">
    <kood>WRC</kood>
    <xs:complexType>
    <sarjaNimi>Autoralli MM-võistlused</sarjaNimi>
      <xs:sequence >
    <etappideArv>13</etappideArv>
         <!-- maakodi võib olla maksimaalselt 90 kuna maakonna kood peab olema unikaalne ja alati kahekohaline integer-->
    <etapp id="2012wrc01">
         <xs:element maxOccurs="90" name="maakond">
      <etapiNr>1.</etapiNr>
           <!-- keelame ära maakonna mixed contenti, sest kõik info on atribuutides ja elemendil endal puudub väärtus -->
      <etapiNimi>Rallye Monte Carlo</etapiNimi>     
           <xs:complexType mixed="false">
      <etapiRiik>Prantsusmaa</etapiRiik>
            <xs:sequence>
      <algKuupaev>18.01.2012</algKuupaev>
              <xs:element maxOccurs="unbounded" name="omavalitsus">
      <loppKuupaev>22.01.2012</loppKuupaev>
                <!-- keelame ära omavalitsuse mixed contenti, sest kõik info on atribuutides ja elemendil endal puudub väärtus -->
      <tulemusRida koht="1.">
                <xs:complexType mixed="false">
        <juht>
                  <xs:sequence >
          <perenimi>Loeb</perenimi>
                    <xs:element maxOccurs="unbounded" name="asustusüksus">
          <eesnimi>Sebastien</eesnimi>
                      <!-- keelame ära asustusüksuse mixed contenti, sest kõik info on atribuutides ja elemendil endal puudub väärtus -->
          <riigikood>FRA</riigikood>
                      <xs:complexType mixed="false">
         </juht>
                        <xs:attribute name="nimi" type="xs:string" use="required" />
         <auto>Citroen</auto>
                        <!-- alati neljakohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
        <punktid>28</punktid>
                        <xs:attribute name="kood" type="xs:unsignedShort" use="required"></xs:attribute>
      </tulemusRida>
                        <!-- alati ühekohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
      <tulemusRida koht="2.">
                        <xs:attribute name="tüüp" type="xs:unsignedByte" use="required" />
        <juht>
                        <xs:attribute name="tüübinimi" type="xs:string" use="required" />
           <perenimi>Sordo</perenimi>
                        <!-- osadel küladel, kus on suur hulk sisserännanuid (Noarootsi) on kasutusel ka võõrkeelne nimi -->
           <eesnimi>Daniel</eesnimi>
                        <xs:attribute name="rööpnimi" type="xs:string" use="optional" />
          <riigikood>ESP</riigikood>
                      </xs:complexType>
        </juht>
                    </xs:element>
        <auto>Mini</auto>
                  </xs:sequence>
        <punktid>18</punktid>
                  <xs:attribute name="nimi" type="xs:string" use="required" />
      </tulemusRida>
                  <!-- alati kolmekohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
      <tulemusRida koht="3.">
                  <xs:attribute name="kood" type="xs:unsignedShort" use="required" />
        <juht>
                  <xs:attribute name="tüübinimi" type="xs:string" use="required" />
          <perenimi>Solberg</perenimi>
                </xs:complexType>
          <eesnimi>Petter</eesnimi>
                <xs:unique name="UnikaalneAsustusüksuseKood">
          <riigikood>NOR</riigikood>
                  <xs:selector xpath="asustusüksus" />
        </juht>
                  <xs:field xpath="@kood" />
        <auto>Ford</auto>
                </xs:unique>
        <punktid>15</punktid>
              </xs:element>
      </tulemusRida>
            </xs:sequence>
      <tulemusRida koht="4.">
            <xs:attribute name="nimi" type="xs:string" use="required"/>
        <juht>
            <!-- alati kahekohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
          <perenimi>Hirvonen</perenimi>
            <xs:attribute name="kood" type="xs:unsignedByte" use="required" />
          <eesnimi>Mikko</eesnimi>
           </xs:complexType>
          <riigikood>FIN</riigikood>
           <xs:unique name="UnikaalneOmavalitsuseKood">
        </juht>
            <xs:selector xpath="omavalitsus" />
        <auto>Citroen</auto>
            <xs:field xpath="@kood" />
        <punktid>14</punktid>
           </xs:unique>
      </tulemusRida>
         </xs:element>
      <tulemusRida koht="5.">
      </xs:sequence>
        <juht>
    </xs:complexType>
          <perenimi>Novikov</perenimi>
    <xs:unique name="UnikaalneMaakonnaKood">
          <eesnimi>Evgeny</eesnimi>
       <xs:selector xpath="maakond" />
          <riigikood>RUS</riigikood>
       <xs:field xpath="@kood" />
        </juht>
    </xs:unique>
        <auto>Ford</auto>
  </xs:element>
        <punktid>11</punktid>
</xs:schema>
      </tulemusRida>
</source>
      <tulemusRida koht="6.">
 
        <juht>
 
          <perenimi>Delecour</perenimi>
===XSLT (esimene)===
          <eesnimi>Francois</eesnimi>
Esimene xslt fail kuvab xml sisu html-is. Iga maakonna all kuvatakse omavalitsused eraldi valdade ja linnade kaupa. Valdade all kuvatakse asustusüksused sorteerituna külade, alevike ja alevite kaupa. Kui külal leidub rööpnimi, kuvatakse ka see.
          <riigikood>FRA</riigikood>
XSLT output on [https://ehak.codeplex.com/SourceControl/changeset/view/16725#261893 siin] ja source on siin:
        </juht>
        <auto>Ford</auto>
        <punktid>8</punktid>
      </tulemusRida>
      <tulemusRida koht="7.">
        <juht>
          <perenimi>Campana</perenimi>
          <eesnimi>Pierre</eesnimi>
          <riigikood>FRA</riigikood>
        </juht>
        <auto>Mini</auto>
        <punktid>6</punktid>
      </tulemusRida>
      <tulemusRida koht="8.">
        <juht>
          <perenimi>Tänak</perenimi>
          <eesnimi>Ott</eesnimi>
          <riigikood>EST</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>4</punktid>
      </tulemusRida>
      <tulemusRida koht="9.">
        <juht>
          <perenimi>Prokop</perenimi>
          <eesnimi>Martin</eesnimi>
          <riigikood>CZE</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>2</punktid>
      </tulemusRida>
      <tulemusRida koht="10.">
        <juht>
          <perenimi>Araujo</perenimi>
          <eesnimi>Armindo</eesnimi>
          <riigikood>PRT</riigikood>
        </juht>
        <auto>Mini</auto>
        <punktid>1</punktid>
      </tulemusRida>
    </etapp>
    <etapp id="2012wrc02">
      <etapiNr>2.</etapiNr>
      <etapiNimi>Rally Sweden</etapiNimi>
      <etapiRiik>Rootsi</etapiRiik>
      <algKuupaev>9.02.2012</algKuupaev>
      <loppKuupaev>12.02.2012</loppKuupaev>
      <tulemusRida koht="1.">
        <juht>
          <perenimi>Latvala</perenimi>
          <eesnimi>Jari-Matti</eesnimi>
          <riigikood>FIN</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>26</punktid>
      </tulemusRida>
      <tulemusRida koht="2.">
        <juht>
          <perenimi>Hirvonen</perenimi>
          <eesnimi>Mikko</eesnimi>
          <riigikood>FIN</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>18</punktid>
      </tulemusRida>
      <tulemusRida koht="3.">
        <juht>
          <perenimi>Ostberg</perenimi>
          <eesnimi>Mads</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>15</punktid>
      </tulemusRida>
      <tulemusRida koht="4.">
        <juht>
          <perenimi>Solberg</perenimi>
          <eesnimi>Petter</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>14</punktid>
      </tulemusRida>
      <tulemusRida koht="5.">
        <juht>
          <perenimi>Loeb</perenimi>
          <eesnimi>Sebastien</eesnimi>
          <riigikood>FRA</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>11</punktid>
      </tulemusRida>
      <tulemusRida koht="6.">
        <juht>
          <perenimi>Novikov</perenimi>
          <eesnimi>Evgeny</eesnimi>
          <riigikood>RUS</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>10</punktid>
      </tulemusRida>
      <tulemusRida koht="7.">
        <juht>
          <perenimi>Solberg</perenimi>
          <eesnimi>Henning</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>6</punktid>
      </tulemusRida>
      <tulemusRida koht="8.">
        <juht>
          <perenimi>Sandell</perenimi>
          <eesnimi>Patrik</eesnimi>
          <riigikood>SWE</riigikood>
        </juht>
        <auto>Mini</auto>
        <punktid>4</punktid>
      </tulemusRida>
      <tulemusRida koht="9.">
        <juht>
          <perenimi>Prokop</perenimi>
          <eesnimi>Martin</eesnimi>
          <riigikood>CZE</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>2</punktid>
      </tulemusRida>
      <tulemusRida koht="10.">
        <juht>
          <perenimi>Brynildsen</perenimi>
          <eesnimi>Eyvind</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>1</punktid>
      </tulemusRida>
    </etapp>
    <etapp id="2012wrc03">
      <etapiNr>3.</etapiNr>
      <etapiNimi>Rally Guanajuato Mexico</etapiNimi>
      <etapiRiik>Mehhiko</etapiRiik>
      <algKuupaev>8.03.2012</algKuupaev>
      <loppKuupaev>11.03.2012</loppKuupaev>
      <tulemusRida koht="1.">
        <juht>
          <perenimi>Loeb</perenimi>
          <eesnimi>Sebastien</eesnimi>
          <riigikood>FRA</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>27</punktid>
      </tulemusRida>
      <tulemusRida koht="2.">
        <juht>
          <perenimi>Hirvonen</perenimi>
          <eesnimi>Mikko</eesnimi>
          <riigikood>FIN</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>18</punktid>
      </tulemusRida>
      <tulemusRida koht="3.">
        <juht>
          <perenimi>Solberg</perenimi>
          <eesnimi>Petter</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>18</punktid>
      </tulemusRida>
      <tulemusRida koht="4.">
        <juht>
          <perenimi>Ostberg</perenimi>
          <eesnimi>Mads</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>13</punktid>
      </tulemusRida>
      <tulemusRida koht="5.">
        <juht>
          <perenimi>Tänak</perenimi>
          <eesnimi>Ott</eesnimi>
          <riigikood>EST</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>10</punktid>
      </tulemusRida>
      <tulemusRida koht="6.">
        <juht>
          <perenimi>Al-Attiyah</perenimi>
          <eesnimi>Nasser</eesnimi>
          <riigikood>QAT</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>8</punktid>
      </tulemusRida>
      <tulemusRida koht="7.">
        <juht>
          <perenimi>Araujo</perenimi>
          <eesnimi>Armindo</eesnimi>
          <riigikood>PRT</riigikood>
        </juht>
        <auto>Mini</auto>
        <punktid>6</punktid>
      </tulemusRida>
      <tulemusRida koht="8.">
        <juht>
          <perenimi>Ogier</perenimi>
          <eesnimi>Sebastien</eesnimi>
          <riigikood>FRA</riigikood>
        </juht>
        <auto>Skoda</auto>
        <punktid>4</punktid>
      </tulemusRida>
      <tulemusRida koht="9.">
        <juht>
          <perenimi>Block</perenimi>
          <eesnimi>Ken</eesnimi>
          <riigikood>USA</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>2</punktid>
      </tulemusRida>
      <tulemusRida koht="10.">
        <juht>
          <perenimi>Trivino</perenimi>
          <eesnimi>Ricardo</eesnimi>
          <riigikood>MEX</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>1</punktid>
      </tulemusRida>
    </etapp>
    <etapp id="2012wrc04">
      <etapiNr>4.</etapiNr>
      <etapiNimi>Vodafone Rally de Portugal</etapiNimi>
      <etapiRiik>Portugal</etapiRiik>
      <algKuupaev>29.03.2012</algKuupaev>
      <loppKuupaev>01.04.2012</loppKuupaev>
      <tulemusRida koht="1.">
        <juht>
          <perenimi>Ostberg</perenimi>
          <eesnimi>Mads</eesnimi>
          <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>25</punktid>
      </tulemusRida>
      <tulemusRida koht="2.">
        <juht>
          <perenimi>Novikov</perenimi>
          <eesnimi>Evgeniy</eesnimi>
          <riigikood>RUS</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>18</punktid>
      </tulemusRida>
      <tulemusRida koht="3.">
        <juht>
          <perenimi>Solberg</perenimi>
           <eesnimi>Petter</eesnimi>
           <riigikood>NOR</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>15</punktid>
      </tulemusRida>
      <tulemusRida koht="4.">
        <juht>
          <perenimi>al-Attiyah</perenimi>
          <eesnimi>Nasser</eesnimi>
          <riigikood>QA</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>12</punktid>
      </tulemusRida>
      <tulemusRida koht="5.">
        <juht>
          <perenimi>Prokop</perenimi>
          <eesnimi>Martin</eesnimi>
          <riigikood>CZ</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>10</punktid>
      </tulemusRida>
      <tulemusRida koht="6.">
        <juht>
          <perenimi>Kuipers</perenimi>
           <eesnimi>Dennis</eesnimi>
          <riigikood>NL</riigikood>
         </juht>
        <auto>Ford</auto>
        <punktid>8</punktid>
      </tulemusRida>
      <tulemusRida koht="7.">
        <juht>
          <perenimi>Ogier</perenimi>
          <eesnimi>Sebastien</eesnimi>
          <riigikood>FRA</riigikood>
        </juht>
        <auto>Skoda</auto>
        <punktid>6</punktid>
      </tulemusRida>
       <tulemusRida koht="8.">
        <juht>
          <perenimi>Neuville</perenimi>
          <eesnimi>Thierry</eesnimi>
          <riigikood>BEL</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>4</punktid>
       </tulemusRida>
      <tulemusRida koht="9.">
        <juht>
          <perenimi>Ketomaa</perenimi>
          <eesnimi>Jari</eesnimi>
          <riigikood>FIN</riigikood>
        </juht>
        <auto>Ford</auto>
        <punktid>2</punktid>
      </tulemusRida>
      <tulemusRida koht="10.">
        <juht>
          <perenimi>van Merksteijn jr</perenimi>
          <eesnimi>Peter</eesnimi>
          <riigikood>NL</riigikood>
        </juht>
        <auto>Citroen</auto>
        <punktid>1</punktid>
      </tulemusRida>
    </etapp>
  </Võistlussari>
  <Võistlussari id="2012irc" aasta="2012">
    <kood>IRC</kood>
    <sarjaNimi>Intercontinental Rally Challenge</sarjaNimi>
    <etappideArv>13</etappideArv>
    <etapp id="2012wrc01">
      <etapiNr>1.</etapiNr>
      <etapiNimi></etapiNimi>
      <etapiRiik></etapiRiik>
      <algKuupaev></algKuupaev>
      <loppKuupaev></loppKuupaev>
      <tulemusRida koht="1.">
        <juht>
          <perenimi></perenimi>
          <eesnimi></eesnimi>
          <riigikood></riigikood>
        </juht>
        <auto></auto>
        <punktid></punktid>
      </tulemusRida>
    </etapp>
  </Võistlussari>
</Autoralli>


===XSLT (kolmas)===
<source lang="xml">
<source lang="xml">
<?xml version="1.0" encoding="utf-8"?>
<?xml version="1.0" encoding="utf-8"?>
Line 437: Line 91:
     xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
     xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
>
>
    <xsl:output method="html" indent="yes"/>
  <xsl:output method="html" indent="yes"/>
 
  <xsl:template match="/">
    <xsl:template match="/">
    <html>
      <html>
      <head>
        <head>
        <title>Superkena haldus- ja asustusüksuste kuvamise leht!</title>
          <title>Autoralli tulemused</title>
      </head>
        </head>
      <body>
        <body>
        <h2>
          <h1>
          Maakonnad, omavalitsused ja asustusüksused
            Fordil võistelnud rallisõitjate kohad esikümnes
        </h2>
          </h1>
        <table border="0">
          <ul>
           <xsl:for-each select="/ehak/maakond">
           <xsl:for-each select="Autoralli/Võistlussari/etapp">
             <tr valign="top">
             <h2>
              <th>
               <xsl:value-of select="etapiNr"/>
                <br/>
              <xsl:text> etapp, </xsl:text>
                <h2>
              <xsl:value-of select="etapiNimi"/>
                  <xsl:value-of select="@nimi"/>
            </h2>
                </h2>
            <h3>
               </th>
              <xsl:value-of select="loppKuupaev"/>
            </tr>
              <xsl:text>, </xsl:text>
            <tr valign="top">
              <xsl:value-of select="etapiRiik"/>
              <th>
            </h3>
                <br/>
            <xsl:for-each select="tulemusRida">
                <i>
              <xsl:if test="auto='Ford'">
                  <b>
            <li>
                    <font size="5">Vallad</font>
              <xsl:value-of select="@koht"/>
                  </b>
              <xsl:text> </xsl:text>
                </i>
              <xsl:value-of select="juht/eesnimi"/>
              </th>
              <xsl:text> </xsl:text>
            </tr>
              <xsl:value-of select="juht/perenimi"/>
            <!-- omavalitsuste puhul on kaks tsüklit - esimene kuvab vallad ja teine linnad-->
              <xsl:text> (</xsl:text>            
            <xsl:for-each select="omavalitsus">
              <xsl:value-of select="juht/riigikood"/>
              <xsl:if test="@tüübinimi='vald'">
              <xsl:text>), </xsl:text>
                <tr valign="top">
               <xsl:value-of select="punktid"/>
                  <th>
              <xsl:text> p.</xsl:text>
                    <br/>
            </li>
                    <xsl:value-of select="@nimi"/>
                    <xsl:text> </xsl:text>
                    <xsl:value-of select="@tüübinimi"/>
                  </th>
                </tr>
                <tr valign="top">
                  <th>
                    <i>Külad, alevikud, alevid</i>
                  </th>
                </tr>
                <!-- asustusüksuste kuvamiseks on kolm tsüklit, sest need kuvatakse sorteeritult
                - esmalt külad, siis alevikud ja lõpuks alevid -->
                <xsl:for-each select="asustusüksus">
                  <xsl:if test="@tüübinimi='küla'">
                    <tr valign="top">
                      <td>
                        <!-- kirjutame nime koos tüübinimega-->
                        <xsl:value-of select="@nimi"/>
                        <xsl:text> </xsl:text>
                        <xsl:value-of select="@tüübinimi"/>
                        <!-- kui leidub rööpnimesid, siis pane need nime järgi, sulgudesse-->
                        <xsl:if test="@rööpnimi">
                          <xsl:text> (</xsl:text>
                          <xsl:value-of select="@rööpnimi"/>
                          <xsl:text>)</xsl:text>
                        </xsl:if>
                      </td>
                    </tr>
                  </xsl:if>
                </xsl:for-each>
                <xsl:for-each select="asustusüksus">
                  <xsl:if test="@tüübinimi='alevik'">
                    <tr valign="top">
                      <td>
                        <!-- kirjutame nime koos tüübinimega-->
                        <xsl:value-of select="@nimi"/>
                        <xsl:text> </xsl:text>
                        <u>
                          <xsl:value-of select="@tüübinimi"/>
                        </u>
                        <!-- kui leidub rööpnimesid, siis pane need nime järgi, sulgudesse-->
                        <xsl:if test="@rööpnimi">
                          <xsl:text> (</xsl:text>
                          <xsl:value-of select="@rööpnimi"/>
                          <xsl:text>)</xsl:text>
                        </xsl:if>
                      </td>
                    </tr>
                  </xsl:if>
                </xsl:for-each>
                <xsl:for-each select="asustusüksus">
                  <xsl:if test="@tüübinimi='alev'">
                    <tr valign="top">
                      <td>
                        <!-- kirjutame nime koos tüübinimega-->
                        <xsl:value-of select="@nimi"/>
                        <xsl:text> </xsl:text>
                        <u>
                          <xsl:value-of select="@tüübinimi"/>
                        </u>
                        <!-- kui leidub rööpnimesid, siis pane need nime järgi, sulgudesse-->
                        <xsl:if test="@rööpnimi">
                          <xsl:text> (</xsl:text>
                          <xsl:value-of select="@rööpnimi"/>
                          <xsl:text>)</xsl:text>
                        </xsl:if>
                      </td>
                    </tr>
                  </xsl:if>
                </xsl:for-each>
               </xsl:if>
            </xsl:for-each>
            <tr valign="top">
              <th>
                <br/>
                <i>
                  <b>
                    <font size="5">Linnad</font>
                  </b>
                </i>
              </th>
            </tr>
            <xsl:for-each select="omavalitsus">
              <xsl:if test="@tüübinimi='linn'">
                <tr valign="top">
                  <th>
                    <br/>
                    <xsl:value-of select="@nimi"/>
                  </th>
                </tr>
                <tr valign="top">
                  <th>
                    <i>Linnaosad</i>
                  </th>
                </tr>
                <!-- kuna linnas saavad ainsaks asustusüksuseks olla linnaosad,
                siis on ainult üks tsükkel ja tüübinime ei kontrollita-->
                <xsl:for-each select="asustusüksus">
                  <tr valign="top">
                    <td>
                      <xsl:value-of select="@nimi"/>
                      <xsl:text> </xsl:text>
                      <xsl:value-of select="@tüübinimi"/>
                    </td>
                  </tr>
                </xsl:for-each>
               </xsl:if>
               </xsl:if>
             </xsl:for-each>
             </xsl:for-each>
           </xsl:for-each>
           </xsl:for-each>
          </ul>
        </table>
         </body>
      </body>
    </html>
  </xsl:template>
</xsl:stylesheet>
</source>
 
===XSLT (teine)===
<source lang="xml">
</source>
 
===XSLT (kolmas)===
<source lang="xml">
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
>
  <xsl:output method="html" indent="yes"/>
  <xsl:template match="/">
    <html>
      <head>
         <title>Rööpnimedega asustusüksuste loetelu</title>
      </head>
      <body>
      <h3>
          Rööpnimedega asustusüksuste nimekiri koos tüübiga
      </h3>
          
          
          
         <table border="1">
          
          <tr>
       </html>
            <th>
    </xsl:template>
              <td>
                <h4>Asustusüksuse nimi</h4>
              </td>
              <td>
                <h4>Asustusüksuse rööpnimi</h4>
              </td>
              <td>
                <h4>Asustusüksuse tüüp</h4>
              </td>
            </th>
          </tr>
          <!-- Valin kõik asustusüksused, millel esineb parameeter "rööpnimi"-->
          <xsl:for-each select="/ehak/maakond/omavalitsus/asustusüksus">
            <xsl:if test="@rööpnimi">
            <tr valign="top">
              <th>
              <!-- Lisan tabelisse soovitud informatsiooni kolmest parameetrist -->
                <td>
                  <xsl:value-of select="@nimi"/>
                </td>
                <td>
                  <xsl:value-of select="@rööpnimi"/>
                </td>
                <td>
                  <xsl:value-of select="@tüübinimi"/>
                </td>
              </th>
            </tr>
            </xsl:if>
          </xsl:for-each>
         </table>
       </body>
    </html>
  </xsl:template>
</xsl:stylesheet>
</xsl:stylesheet>
 
</source>


==Veebiteenus==
==Veebiteenus==
Line 492: Line 309:


==Log==
==Log==
===3. mai 2012 - neljapäev===
Kristjan ja Holger arutasid skypes XML teemal,
Kristjan pakkus õppejõule välja variandi teha XML EHAKist,
tegi codeplexi konto ja lisas sinna ka Holgeri kasutaja
ja tegi xml faili.
===4. mai 2012 - reede===
Kristjan tegi xsd faili ja ühe xslt faili ning lisas Ragnari kasutaja codeplexi.
Lepiti kokku, et ülejäänud kaks xslt-d ja retsensioonid teise grupi xml faili kohta teevad Ragnar ja Holger.


===5. mai 2012 - laupäev===
===5. mai 2012 - laupäev===
Mart tegi xml faili ja xsd faili.
Kristjan lõi meeskonna wiki lehe ja tõstis sinna seni tehtud materjalid


===6. mai 2012 - pühapäev===
===6. mai 2012 - pühapäev===
Mart lõi meeskonna wiki lehe ja tõstis sinna seni tehtud materjalid
Holger lisas enda XSLT koodi wikisse - järjenumbriga 3.

Revision as of 00:34, 7 May 2012

Meeskond

  • Kairi Jaano
  • Mart Mägi
  • Riho Kukk

Meeskond

  • Kristjan Roosild
  • Ragnar Rattas
  • Holger Rünkaru

XML

Luua XML fail andmete edastamiseks, selle XML faili skeemifail ning paar kolm sobivat XSL faili loodud XML failis olevate andmete transformeerimiseks HTML formaati ja XML faili formaadi muutmiseks. XML-il peab olema vähemalt 4 loogilist dimensiooni. Lisaks tuleb kasutada 3-el dimensioonil attribuute, mis on enamat, kui lihtsalt ID.

XML

XML fail sisaldab andmeid Eesti haldus- ja asustusüksuste (EHAK) kohta. Andmed saadi siit. Statistikaametil on küll juba olemas EHAKi xml, kuid see ei ole just kõige paremini loetav, sellepärast proovisimegi ise parema teha.

Link codeplexis olevale xml-ile (see on liiga suur siia panekuks).

XML schema (XSD)

<?xml version="1.0" encoding="utf-8"?>
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <xs:element name="ehak">
    <xs:complexType>
      <xs:sequence >
        <!-- maakodi võib olla maksimaalselt 90 kuna maakonna kood peab olema unikaalne ja alati kahekohaline integer-->
        <xs:element maxOccurs="90" name="maakond">
          <!-- keelame ära maakonna mixed contenti, sest kõik info on atribuutides ja elemendil endal puudub väärtus -->
          <xs:complexType mixed="false">
            <xs:sequence>
              <xs:element maxOccurs="unbounded" name="omavalitsus">
                <!-- keelame ära omavalitsuse mixed contenti, sest kõik info on atribuutides ja elemendil endal puudub väärtus -->
                <xs:complexType mixed="false">
                  <xs:sequence >
                    <xs:element maxOccurs="unbounded" name="asustusüksus">
                      <!-- keelame ära asustusüksuse mixed contenti, sest kõik info on atribuutides ja elemendil endal puudub väärtus -->
                      <xs:complexType mixed="false">
                        <xs:attribute name="nimi" type="xs:string" use="required" />
                        <!-- alati neljakohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
                        <xs:attribute name="kood" type="xs:unsignedShort" use="required"></xs:attribute>
                        <!-- alati ühekohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
                        <xs:attribute name="tüüp" type="xs:unsignedByte" use="required" />
                        <xs:attribute name="tüübinimi" type="xs:string" use="required" />
                        <!-- osadel küladel, kus on suur hulk sisserännanuid (Noarootsi) on kasutusel ka võõrkeelne nimi -->
                        <xs:attribute name="rööpnimi" type="xs:string" use="optional" />
                      </xs:complexType>
                    </xs:element>
                  </xs:sequence>
                  <xs:attribute name="nimi" type="xs:string" use="required" />
                  <!-- alati kolmekohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
                  <xs:attribute name="kood" type="xs:unsignedShort" use="required" />
                  <xs:attribute name="tüübinimi" type="xs:string" use="required" />
                </xs:complexType>
                <xs:unique name="UnikaalneAsustusüksuseKood">
                  <xs:selector xpath="asustusüksus" />
                  <xs:field xpath="@kood" />
                </xs:unique>
              </xs:element>
            </xs:sequence>
            <xs:attribute name="nimi" type="xs:string" use="required"/>
            <!-- alati kahekohaline positiivne integer - seda peaks kuidagi saama pareimini ära määrata/piirata...-->
            <xs:attribute name="kood" type="xs:unsignedByte" use="required" />
          </xs:complexType>
          <xs:unique name="UnikaalneOmavalitsuseKood">
            <xs:selector xpath="omavalitsus" />
            <xs:field xpath="@kood" />
          </xs:unique>
        </xs:element>
      </xs:sequence>
    </xs:complexType>
    <xs:unique name="UnikaalneMaakonnaKood">
      <xs:selector xpath="maakond" />
      <xs:field xpath="@kood" />
    </xs:unique>
  </xs:element>
</xs:schema>


XSLT (esimene)

Esimene xslt fail kuvab xml sisu html-is. Iga maakonna all kuvatakse omavalitsused eraldi valdade ja linnade kaupa. Valdade all kuvatakse asustusüksused sorteerituna külade, alevike ja alevite kaupa. Kui külal leidub rööpnimi, kuvatakse ka see. XSLT output on siin ja source on siin:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
>
  <xsl:output method="html" indent="yes"/>
  <xsl:template match="/">
    <html>
      <head>
        <title>Superkena haldus- ja asustusüksuste kuvamise leht!</title>
      </head>
      <body>
        <h2>
          Maakonnad, omavalitsused ja asustusüksused
        </h2>
        <table border="0">
          <xsl:for-each select="/ehak/maakond">
            <tr valign="top">
              <th>
                <br/>
                <h2>
                  <xsl:value-of select="@nimi"/>
                </h2>
              </th>
            </tr>
            <tr valign="top">
              <th>
                <br/>
                <i>
                  <b>
                    <font size="5">Vallad</font>
                  </b>
                </i>
              </th>
            </tr>
            <!-- omavalitsuste puhul on kaks tsüklit - esimene kuvab vallad ja teine linnad-->
            <xsl:for-each select="omavalitsus">
              <xsl:if test="@tüübinimi='vald'">
                <tr valign="top">
                  <th>
                    <br/>
                    <xsl:value-of select="@nimi"/>
                    <xsl:text> </xsl:text>
                    <xsl:value-of select="@tüübinimi"/>
                  </th>
                </tr>
                <tr valign="top">
                  <th>
                    <i>Külad, alevikud, alevid</i>
                  </th>
                </tr>
                <!-- asustusüksuste kuvamiseks on kolm tsüklit, sest need kuvatakse sorteeritult
                 - esmalt külad, siis alevikud ja lõpuks alevid -->
                <xsl:for-each select="asustusüksus">
                  <xsl:if test="@tüübinimi='küla'">
                    <tr valign="top">
                      <td>
                        <!-- kirjutame nime koos tüübinimega-->
                        <xsl:value-of select="@nimi"/>
                        <xsl:text> </xsl:text>
                        <xsl:value-of select="@tüübinimi"/>
                        <!-- kui leidub rööpnimesid, siis pane need nime järgi, sulgudesse-->
                        <xsl:if test="@rööpnimi">
                          <xsl:text> (</xsl:text>
                          <xsl:value-of select="@rööpnimi"/>
                          <xsl:text>)</xsl:text>
                        </xsl:if>
                      </td>
                    </tr>
                  </xsl:if>
                </xsl:for-each>
                <xsl:for-each select="asustusüksus">
                  <xsl:if test="@tüübinimi='alevik'">
                    <tr valign="top">
                      <td>
                        <!-- kirjutame nime koos tüübinimega-->
                        <xsl:value-of select="@nimi"/>
                        <xsl:text> </xsl:text>
                        <u>
                          <xsl:value-of select="@tüübinimi"/>
                        </u>
                        <!-- kui leidub rööpnimesid, siis pane need nime järgi, sulgudesse-->
                        <xsl:if test="@rööpnimi">
                          <xsl:text> (</xsl:text>
                          <xsl:value-of select="@rööpnimi"/>
                          <xsl:text>)</xsl:text>
                        </xsl:if>
                      </td>
                    </tr>
                  </xsl:if>
                </xsl:for-each>
                <xsl:for-each select="asustusüksus">
                  <xsl:if test="@tüübinimi='alev'">
                    <tr valign="top">
                      <td>
                        <!-- kirjutame nime koos tüübinimega-->
                        <xsl:value-of select="@nimi"/>
                        <xsl:text> </xsl:text>
                        <u>
                          <xsl:value-of select="@tüübinimi"/>
                        </u>
                        <!-- kui leidub rööpnimesid, siis pane need nime järgi, sulgudesse-->
                        <xsl:if test="@rööpnimi">
                          <xsl:text> (</xsl:text>
                          <xsl:value-of select="@rööpnimi"/>
                          <xsl:text>)</xsl:text>
                        </xsl:if>
                      </td>
                    </tr>
                  </xsl:if>
                </xsl:for-each>
              </xsl:if>
            </xsl:for-each>
            <tr valign="top">
              <th>
                <br/>
                <i>
                  <b>
                    <font size="5">Linnad</font>
                  </b>
                </i>
              </th>
            </tr>
            <xsl:for-each select="omavalitsus">
              <xsl:if test="@tüübinimi='linn'">
                <tr valign="top">
                  <th>
                    <br/>
                    <xsl:value-of select="@nimi"/>
                  </th>
                </tr>
                <tr valign="top">
                  <th>
                    <i>Linnaosad</i>
                  </th>
                </tr>
                <!-- kuna linnas saavad ainsaks asustusüksuseks olla linnaosad, 
                siis on ainult üks tsükkel ja tüübinime ei kontrollita-->
                <xsl:for-each select="asustusüksus">
                  <tr valign="top">
                    <td>
                      <xsl:value-of select="@nimi"/>
                      <xsl:text> </xsl:text>
                      <xsl:value-of select="@tüübinimi"/>
                    </td>
                  </tr>
                </xsl:for-each>
              </xsl:if>
            </xsl:for-each>
          </xsl:for-each>
        </table>
      </body>
    </html>
  </xsl:template>
</xsl:stylesheet>

XSLT (teine)

XSLT (kolmas)

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
>
  <xsl:output method="html" indent="yes"/>
  <xsl:template match="/">
    <html>
      <head>
        <title>Rööpnimedega asustusüksuste loetelu</title>
      </head>
      <body>
       <h3>
          Rööpnimedega asustusüksuste nimekiri koos tüübiga
       </h3>
        
        <table border="1">
          <tr>
            <th>
              <td>
                <h4>Asustusüksuse nimi</h4>
              </td>
              <td>
                <h4>Asustusüksuse rööpnimi</h4>
              </td>
              <td>
                <h4>Asustusüksuse tüüp</h4>
              </td>
            </th>
          </tr>
          <!-- Valin kõik asustusüksused, millel esineb parameeter "rööpnimi"-->
          <xsl:for-each select="/ehak/maakond/omavalitsus/asustusüksus">
            <xsl:if test="@rööpnimi">
            <tr valign="top">
              <th>
               <!-- Lisan tabelisse soovitud informatsiooni kolmest parameetrist --> 
                <td>
                  <xsl:value-of select="@nimi"/>
                </td>
                <td>
                  <xsl:value-of select="@rööpnimi"/>
                </td>
                <td>
                  <xsl:value-of select="@tüübinimi"/>
                </td>
              </th>
            </tr>
            </xsl:if>
          </xsl:for-each>
        </table>
      </body>
    </html>
  </xsl:template>
</xsl:stylesheet>

Veebiteenus

Klientrakendus

Log

3. mai 2012 - neljapäev

Kristjan ja Holger arutasid skypes XML teemal, Kristjan pakkus õppejõule välja variandi teha XML EHAKist, tegi codeplexi konto ja lisas sinna ka Holgeri kasutaja ja tegi xml faili.

4. mai 2012 - reede

Kristjan tegi xsd faili ja ühe xslt faili ning lisas Ragnari kasutaja codeplexi. Lepiti kokku, et ülejäänud kaks xslt-d ja retsensioonid teise grupi xml faili kohta teevad Ragnar ja Holger.

5. mai 2012 - laupäev

Kristjan lõi meeskonna wiki lehe ja tõstis sinna seni tehtud materjalid

6. mai 2012 - pühapäev

Holger lisas enda XSLT koodi wikisse - järjenumbriga 3.