Project

iev

0.01
A long-lived project that still receives updates
Iev: Fetch and encode Iev term from Electropedia
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

~> 2.5
>= 2.3.0
~> 1.18
~> 5.40
~> 1.7.0
~> 1.0
~> 2.4
>= 1.16.5
 Project Readme

IEV: Utilities for the International Electrotechnical Vocabulary (IEC Electropedia)

Gem Version Build Status Code Climate Pull Requests Commits since latest

Purpose

This library allows accessing data of the International Electrotechnical Vocabulary (IEV):

  • Access IEV terms remotely, via the Electropedia website (www.electropedia.org)

  • Read IEV terms from an offline IEV termbase in Glossarist format

  • Parse an IEV exported Excel file and convert its contents into a Glossarist termbase

Warning
The last feature is only meant for IEC-internal use. The IEV export files can only be obtained from the IEC IT department.
Note
The iev-data gem is obsolete by this library and its functionality has been fully incorporated into this library.

Install

Add this line to your Gemfile:

gem 'iev'

And then execute:

$ bundle

Or install it yourself as:

$ gem install iev

Usage

The gem comes with the iev executable, which provides the following commands:

iev xlsx2yaml FILE

Converts Excel IEV exports to YAMLs.

iev xlsx2db FILE

Imports Excel to SQLite database.

iev db2yaml DB_FILE

Exports SQLite to IEV YAMLs.

Warning
The IEV XLSX export files can only be obtained from the IEC Electropedia administrator.

Fetching IEV terms from Electropedia

# Get term

Iev.get("103-01-02", "en")
=> "functional"

# If code not found
Iev.get("111-11-11", "en")
=> ""

# If language not found
Iev.get("103-01-02", "eee")
=> nil

Converting IEV Excel exports to a Glossarist dataset

Run the following command:

$ iev xlsx2yaml [termbase.xlsx]

Where,

  • the Glossarist termbase YAML files will be created at [termbase.yaml] at the current working directory;

  • ConceptYAML files for each concept (each concept identified by a unique “Term-ID”) are created under the concepts/ directory (based on the current working directory). i.e. concepts/concept-338.yaml.

Structure of the IEV Excel export

The columns are:

IEVREF

concept ID of this term

LANGUAGE

ISO 639-1 code (2 character)

TERM

the designation of this concept in language of LANGUAGE

TERMATTRIBUTE

a field of multiple uses, an array (separated by ;). More details below.

SYNONYM1

a synonym of this term

SYNONYM1ATTRIBUTE

the TERMATTRIBUTE that applies to SYNONYM1

SYNONYM1STATUS

One of Preferred, Deprecated, nil.

SYNONYM2

second synonym of this term

SYNONYM2ATTRIBUTE

the TERMATTRIBUTE that applies to SYNONYM2

SYNONYM2STATUS

One of Preferred, Deprecated, nil.

SYNONYM3

3rd synonym of this term

SYNONYM3ATTRIBUTE

the TERMATTRIBUTE that applies to SYNONYM3

SYNONYM3STATUS

One of Preferred, Deprecated, nil.

SYMBOLE

Math symbol

DEFINITION

definition text that includes <note> and <example>

SOURCE

which document was this term was taken from

PUBLICATIONDATE

YYYY-MM date of publication

STATUS

Only Standard for now

REPLACES

IEVREF for the deprecated term

Term field

  • Usually the text

  • If it is …​.. (5 dots), it means that the translation is not available.

  • If it is foobar (acronym) or foobar (akronim), it is an acronym. term.acronymtrue.

Term attribute field

There are these data types inside the term attribute field. Make sure you split at ; for multiple entries.

f or m or n

this means term.grammar-gender is one of them, term.pluralitysingular

n pl

term.grammar-gendern, term.pluralityplural

m pl

term.grammar-genderm, term.pluralityplural

f pl

term.grammar-genderf, term.pluralityplural

pl

term.pluralityplural (else, singular)

(in Zusammensetzungen) f

term.compound-prefix ⇒ true, term.grammar-genderf

(in Zusammensetzungen) m

term.compound-prefix ⇒ true, term.grammar-genderm

m, (abgelehnt)

term.rejected ⇒ true, term.grammar-genderm

f, (abgelehnt)

term.rejected ⇒ true, term.grammar-genderf

(略語)

term.abbreviation ⇒ true

<…​>

this means the text (…​) inside is the domain of this term (which field this term applies in)

<相关条目:[SOMEIEVREF]>

SOMEIEVREF here represents the "related to" term. Add a relationship of this term to SOMEIEVREF.

Adjektiv, adj, 形容詞, 형용사

sets term.grammar-particle to adj

Präfix, (prefix), (préfixe), 接尾語, 접두사, (词头)

sets term.affix to prefix

CA

term.geographical_areaCA

US

term.geographical_areaUS

noun, 名詞

term.grammar-particlenoun (all terms default to noun)

verb, 動詞

term.grammar-particleverb

(sigle international), mterm.acronym = true, term.international = true, term.gender = 'm'

Term definition field

We need to parse out all NOTEs and EXAMPLEs and normalize them.

For all This links to <a href=IEV112-01-01>quantity</a>, we parse them and replace with: This links to {{quantity, IEV:112-01-01}}.

e.g.

  1. Every <NOTE {N} - goes into a separate entry under notes::

quotient of two quantities of different dimensions, used as a multiplier to express the proportionality equation between them
<NOTE 1 – A coefficient is a quantity having a dimension other than one. Examples: Hall coefficient, damping coefficient, temperature coefficient, gyromagnetic coefficient.
<NOTE 2 – The term "modulus" is sometimes used instead of coefficient. Example: modulus of elasticity.
definition: quotient of two quantities of different dimensions, used as a multiplier to express the proportionality equation between them
notes:
  - A coefficient is a quantity having a dimension other than one. Examples: Hall coefficient, damping coefficient, temperature coefficient, gyromagnetic coefficient.
  - The term "modulus" is sometimes used instead of coefficient. Example: modulus of elasticity.
  1. A <NOTE - goes into notes::

quantity of dimension one defined by a combination of quantities
<NOTE – Characteristic numbers occur in particular in the theory of similarity. They carry the word "number" in their names. Examples: Reynolds number, Prandtl number.
definition:
notes:
  - Characteristic numbers occur in particular in the theory of similarity. They carry the word "number" in their names. Examples: Reynolds number, Prandtl number.
  1. Sometimes there are many Note {N} to entry: `, they are identical to `NOTE -.

set of interrelated items that collectively fulfil a requirement
<p>Note 1 to entry: A system is considered to have a defined real or abstract boundary.
<p>Note 2 to entry: External resources (from outside the system boundary) may be required for the system to operate.
<p>Note 3 to entry: A system structure may be hierarchical, e.g. system, subsystem, component, etc.
<p>Note 4 to entry: Conditions of use and maintenance should be expressed or implied within the requirement.
definition: set of interrelated items that collectively fulfil a requirement
notes:
  - A system is considered to have a defined real or abstract boundary.
  - External resources (from outside the system boundary) may be required for the system to operate.
  - A system structure may be hierarchical, e.g. system, subsystem, component, etc.
  - Conditions of use and maintenance should be expressed or implied within the requirement.
  1. Parse EXAMPLE:

<a href=IEV112-01-01>quantity</a> which keeps the same value under particular circumstances, or which results from theoretical considerations
<p>EXAMPLE <a href=IEV103-05-26>time constant</a>, equilibrium constant for a chemical reaction, <a href=IEV112-03-09>fundamental physical constant</a>.

definition: {{quantity, IEV:112-01-01}} which keeps the same value under particular circumstances, or which results from theoretical considerations
examples:
  - {{time constant, IEV:103-05-26}}, equilibrium constant for a chemical reaction, {{fundamental physical constant, IEV:112-03-09}}.
  1. Remember to parse both EXAMPLE and Note {N} to entry:.

level of sub-division within a system hierarchy
<p>EXAMPLE System, subsystem, assembly, and component. <p>Note 1 to entry: From the maintenance perspective, the indenture level depends upon various factors, including the complexity of the item's construction, the accessibility of sub items, skill level of maintenance personnel, test equipment facilities, and safety considerations.
definition: level of sub-division within a system hierarchy
examples:
  - System, subsystem, assembly, and component.
notes:
  - From the maintenance perspective, the indenture level depends upon various factors, including the complexity of the item's construction, the accessibility of sub items, skill level of maintenance personnel, test equipment facilities, and safety considerations.
  1. Remember to parse both EXEMPLE and Note {N} à l’article: in French

niveau de subdivision à l’intérieur de la hiérarchie d’un système
<p>EXEMPLE Système, sous-système, assemblage et composant. <p>Note 1 à l’article: Du point de vue de la maintenance, le niveau dans l’arborescence dépend de divers facteurs dont la complexité de la structure de l’entité, l’accessibilité aux sous-entités, le niveau de compétence du personnel de maintenance, les moyens de mesure et d’essai, et des considérations de sécurité.
definition: niveau de subdivision à l’intérieur de la hiérarchie d’un système
examples:
  - Système, sous-système, assemblage et composant.
notes:
  - Du point de vue de la maintenance, le niveau dans l’arborescence dépend de divers facteurs dont la complexité de la structure de l’entité, l’accessibilité aux sous-entités, le niveau de compétence du personnel de maintenance, les moyens de mesure et d’essai, et des considérations de sécurité.

Source field

Original:

IEC 60050-311:2001, 311-01-04

After parsing:

authoritative_source:
  ref: IEC 60050-311:2001, 311-01-04

Data copyright IEC. All others copyright Ribose.