Извлечение данных из XBRL с помощью XPath

Я пытаюсь извлечь некоторые данные из файла XBRL, используя выражение XPath в Talend Studio. Я хочу извлечь все значения ShareHolderFunds и дату окончания периода, к которому он относится (на который ссылается атрибут «ContextRef»), а также регистрационный номер компании. Я изо всех сил пытаюсь сделать ссылку на дату окончания периода - на данный момент мой код неправильно возвращает одну и ту же дату окончания для обоих значений ShareHolderFund.

Вот скриншот моего кода Talend Studio:

Talend Studio

А вот выдержка из XBRL:

<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="http://www.companieshouse.gov.uk/ef/xbrl/uk/fr/gaap/ae/2009-06-21/stylesheet/CH-AE-stylesheet.xsl"?>
<xbrl xmlns="http://www.xbrl.org/2003/instance" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:ae="http://www.companieshouse.gov.uk/ef/xbrl/uk/fr/gaap/ae/2009-06-21" xmlns:gc="http://www.xbrl.org/uk/fr/gcd/2004-12-01" xmlns:html="http://www.w3.org/1999/xhtml" xmlns:iso4217="http://www.xbrl.org/2003/iso4217" xmlns:link="http://www.xbrl.org/2003/linkbase" xmlns:pt="http://www.xbrl.org/uk/fr/gaap/pt/2004-12-01" xmlns:xbrli="http://www.xbrl.org/2003/instance" xmlns:xlink="http://www.w3.org/1999/xlink">
<link:schemaRef xlink:arcrole="http://www.w3.org/1999/xlink/properties/linkbase" xlink:href="http://www.companieshouse.gov.uk/ef/xbrl/uk/fr/gaap/ae/2009-06-21/uk-gaap-ae-2009-06-21.xsd" xlink:type="simple" />
<ae:CompanyNotDormant contextRef="y2013">true</ae:CompanyNotDormant>
<gc:EntityNames>
  <gc:EntityCurrentLegalName contextRef="y2013">A &amp; Co. Limited</gc:EntityCurrentLegalName>
</gc:EntityNames>
<ae:CompanyIdentifyingNumbers>
  <ae:CompaniesHouseRegisteredNumber contextRef="y2013">123456</ae:CompaniesHouseRegisteredNumber>
</ae:CompanyIdentifyingNumbers>
<gc:StatementDatesPeriodsCovered>
  <gc:BalanceSheetDate contextRef="e2013">2013-03-31</gc:BalanceSheetDate>
</gc:StatementDatesPeriodsCovered>

<pt:ShareholderFunds precision="5" contextRef="e2013" unitRef="GBP">5286</pt:ShareholderFunds>
<pt:ShareholderFunds precision="5" contextRef="e2012" unitRef="GBP">5446</pt:ShareholderFunds>

<unit id="shares">
  <measure>xbrli:shares</measure>
</unit>
<unit id="GBP">
  <measure>iso4217:GBP</measure>
</unit>
<unit id="pure">
  <measure>xbrli:pure</measure>
</unit>

<context id="e2012">
  <entity>
    <identifier scheme="Ellco/results">A &amp; Co. Limited</identifier>
  </entity>
  <period>
    <instant>2012-03-31</instant>
  </period>
</context>
<context id="s2013">
  <entity>
    <identifier scheme="Ellco/results">A &amp; Co. Limited</identifier>
  </entity>
  <period>
    <instant>2012-03-31</instant>
  </period>
</context>
<context id="e2013">
  <entity>
    <identifier scheme="Ellco/results">A &amp; Co. Limited</identifier>
  </entity>
  <period>
    <instant>2013-03-31</instant>
  </period>
</context>
<ae:CompaniesHouseDocumentAuthentication contextRef="y2013"> </ae:CompaniesHouseDocumentAuthentication>
<ae:DateAccountsReceived contextRef="e2013">2013-12-25</ae:DateAccountsReceived>
</xbrl>

person Aeolai    schedule 16.02.2014    source источник


Ответы (1)


Используя XPath, я смог выбрать две разные даты с помощью этого кода:

/xbrl/context[@id = /xbrl/pt:ShareholderFunds/@contextRef]/period/instant

Выражение выбирает элементы xbrl/context, которые имеют атрибут id, соответствующий атрибуту /xbrl/pt:ShareholderFunds contextRef, и получает period/instant в каждом из них. Результатом выбора является набор узлов, содержащий:

2012-03-31
2013-03-31
person helderdarocha    schedule 16.02.2014