ONYX - 9.0 - Utilisation - Gestion d'indexation/en

Différence entre versions

De MappingDoc
(Page créée avec « ONYX:9.0:Utilisation:XPS Indexation management »)
 
(Page créée avec « Concatenation in several times, in the case where we do not know in advance the number of input XPS files (generally in a loop): map_xps -tempfile:/tmp/final.xps -add:/tm... »)
 
(61 révisions intermédiaires par le même utilisateur non affichées)
Ligne 1 : Ligne 1 :
 
<languages/>
 
<languages/>
==Liste des index et de leurs valeurs==
+
==List of indexes and their values==
  
  
Le commutateur -dumpIndex permet de lister tous les critères d’indexation présents dans le document XPS.
+
The -dumpIndex toggle allows you to list all the indexing criteria present in the XPS document.
  
Exemple:
+
 
 +
Example:
 
  map_xps -infile:/tmp/invoice.xps -dumpIndex
 
  map_xps -infile:/tmp/invoice.xps -dumpIndex
 
  CustomerID
 
  CustomerID
Ligne 13 : Ligne 14 :
 
  MAPSUBJCT
 
  MAPSUBJCT
 
  MAPSEND
 
  MAPSEND
  NUMPAGE
+
  NUMPING
  
Utilisé avec le nom d’un index en particulier, il liste l’ensemble des valeurs différentes de cet index :
+
Used with the name of a particular index, it lists all the different values ​​of this index:
 
  map_xps -infile:/tmp/invoice.xps -dumpIndex:CustomerID
 
  map_xps -infile:/tmp/invoice.xps -dumpIndex:CustomerID
 
  10638
 
  10638
Ligne 23 : Ligne 24 :
 
  ...
 
  ...
  
En rajoutant le commutateur <code>-duplicateindex</code>, les valeurs de l’index sont listées sur toutes les pages du document XPS y compris celles qui ont la même valeur :
+
 
 +
By adding the <code>-duplicateindex</code> switch, the index values ​​are listed on all pages of the XPS document including those with the same value:
  
 
  map_xps -infile:/tmp/invoice.xps -dumpIndex:CustomerID -duplicateindex
 
  map_xps -infile:/tmp/invoice.xps -dumpIndex:CustomerID -duplicateindex
Ligne 34 : Ligne 36 :
 
  ...
 
  ...
  
==Indexation d'un document==
+
==Indexing a document==
 +
 
  
 +
===Replications of index values===
  
===Réplications des valeurs d'un index===
 
  
Dans certains cas, il se peut qu’un critère d’indexation soit bien présent sur toutes les pages mais sans valeur définie pour certaines pages ou bien que le critère d’indexation ne soit pas présent sur toutes les pages. Le commutateur '''copyEmptyIndex''' permet alors de réindexer le document en copiant, pour les pages sans valeur d’index, la valeur de l’index se trouvant sur la page précédente.
+
In certain cases, it may be that an indexing criterion is present on all pages but without a defined value for certain pages or that the indexing criterion is not present on all pages. The '''copyEmptyIndex''' switch then allows you to reindex the document by copying, for pages without an index value, the index value found on the previous page.
  
Exemple :
+
 
 +
Example :
 
  map_xps -infile:/tmp/invoice.xps -copyEmptyIndex:InvoiceID
 
  map_xps -infile:/tmp/invoice.xps -copyEmptyIndex:InvoiceID
  
Indexation du fichier avant passage de la commande :
+
Indexing the file before placing the order:
 
{| class="wikitable"
 
{| class="wikitable"
 
|-
 
|-
! Page !! Index !! Valeur de l’index
+
! Page!! Index!! Index value
 
|-
 
|-
 
| 1 || InvoiceID || 1
 
| 1 || InvoiceID || 1
 
|-
 
|-
| 2 ||  || Texte de la cellule
+
| 2 ||  || Cell text
 
|-
 
|-
 
| 3|| InvoiceID || 2
 
| 3|| InvoiceID || 2
Ligne 57 : Ligne 61 :
 
| 4 || InvoiceID || 3
 
| 4 || InvoiceID || 3
 
|-
 
|-
| 5 || InvoiceID || Texte de la cellule
+
| 5 || InvoiceID || Cell text
 
|}
 
|}
  
Indexation du fichier après passage de la commande :
+
 
 +
Indexing the file after placing the order:
  
 
{| class="wikitable"
 
{| class="wikitable"
Ligne 78 : Ligne 83 :
  
  
===Ajout de critères d'indexation(Statique)===
 
  
Le commutateur <code>-addCriteria</code> permet d’ajouter un ou plusieurs critères sur un document. La syntaxe générale est :
+
===Addition of indexing criteria (Static)===
-addCriteria:Nom_index=valeur
 
  
  
Exemple : ajout d’un ou plusieurs index avec la même valeur sur toutes les pages
+
The <code>-addCriteria</code> switch allows you to add one or more criteria to a document. The general syntax is:
 +
-addCriteria:IndexName=value
 +
 
 +
 
 +
 
 +
Example: adding one or more indexes with the same value on all pages
 
  map_xps -infile:/tmp/in.xps -outfile:/tmp/out.xps -addCriteria:NumOrder=123456 -addCriteria:Date=17.02.2015
 
  map_xps -infile:/tmp/in.xps -outfile:/tmp/out.xps -addCriteria:NumOrder=123456 -addCriteria:Date=17.02.2015
  
  
===Ajout de critères d'indexation(Dynamique)===
 
  
Plus généralement, les valeurs de l’index ajouté seront issues d’une extraction préalable d’informations texte contenues dans le document XPS lui-même sur chacune de ses pages. Ces informations, stockées temporairement dans un fichier /tmp/values.txt, sont réutilisées pour l’ajout du critère avec la syntaxe suivante :
+
===Addition of indexing criteria (Dynamic)===
 +
 
 +
 
 +
More generally, the values ​​of the added index will come from a prior extraction of text information contained in the XPS document itself on each of its pages. This information, temporarily stored in a /tmp/values.txt file, is reused to add the criterion with the following syntax:
  
  map_xps "-infile:/tmp/in.xps" "-outfile:/tmp/out.xps" "-addCriteria:NumOrder=FILE:/tmp/value.txt"
+
   
 +
map_xps "-infile:/tmp/in.xps" "-outfile:/tmp/out.xps" "-addCriteria:NumOrder=FILE:/tmp/value.txt"
  
===Extraction des valeurs de critère===
+
===Extracting criterion values===
  
Le principe est de rechercher des informations contenues dans le document et de les extraire (commutateur '''-extract:xxx''') dans un fichier temporaire pour ensuite les ajouter comme valeurs d’un critère d’indexation du même document. Le fichier temporaire créé est au format texte, en Unicode, avec la syntaxe suivante : « '''valeur[TAB]page[CRLF]''' ».
+
The principle is to search for information contained in the document and extract it ('''-extract:xxx''' switch) into a temporary file and then add them as values ​​of an indexing criterion of the same document. The temporary file created is in text format, in Unicode, with the following syntax: "'''value[TAB]page[CRLF]'''".
La collecte des informations dans le document peut se faire par mot clé (commutateur '''-filter:xxx''') ou par position (commutateur -'''box:xxx''').
+
The collection of information in the document can be done by keyword ('''-filter:xxx''' switch) or by position (-'''box:xxx''' switch).
Les informations retournées peuvent être nettoyées des espaces superflus avant et/ou après le texte avec les commutateurs suivants :
+
The returned information can be cleaned of extraneous spaces before and/or after the text with the following switches:
  '''-ltrim''' : suppression des espaces avant le texte
+
  '''-ltrim''': removing spaces before the text
  
  '''-rtrim''' : suppression des espaces après le texte
+
   
 +
'''-rtrim''': removing spaces after the text
  
  '''-trim''' : suppression des espaces avant et après le texte
+
   
 +
'''-trim''': removal of spaces before and after the text
  
Exemple 1 : recherche par mot clé
+
Example 1: Keyword search
 
  map_xps "-infile:/tmp/invoice.xps" "-extract:/tmp/values.txt" "-filter:Invoice for order" "-length:10" "-shift:2" "-rtrim"
 
  map_xps "-infile:/tmp/invoice.xps" "-extract:/tmp/values.txt" "-filter:Invoice for order" "-length:10" "-shift:2" "-rtrim"
&rArr; extraction de 10 caractères situés deux caractères après le mot cléInvoice for orderen supprimant les espaces superflus après le texte retourné.
+
&rArr; extraction of 10 characters located two characters after the keyword Invoice for order by removing unnecessary spaces after the returned text.
  
Exemple 2 : recherche par position
+
Example 2: search by position
 
  map_xps "-infile:/tmp/invoice.xps" "-extract:/tmp/values.txt" "-box:100,150,180,30,mm"
 
  map_xps "-infile:/tmp/invoice.xps" "-extract:/tmp/values.txt" "-box:100,150,180,30,mm"
  
Les paramètres de la box précisent ses dimensions : xx.xx,xx.xx,xx.xx,xx.xx[,cm|in|mm]
 
  
- quatre nombres décimaux spécifiant dans l’ordre : top (haut), bottom (bas), left (gauche), right (droite)
+
The box parameters specify its dimensions: xx.xx,xx.xx,xx.xx,xx.xx[,cm|in|mm]
 +
 
 +
 
 +
- four decimal numbers specifying in order: top, bottom, left, right
 +
 
 +
 
 +
- the decimal separator is ‘.’
 +
 
  
- le séparateur de décimale est le .
+
- the value separator is ,’ or ‘;
  
- le séparateur de valeurs est ‘,’ ou ‘;’
 
  
- le dernier paramètre (optionnel) est l’unité des coordonnées : en points (pour une résolution de 96dpi) par défaut, en millimètres (mm), en pouces (in) ou en centimètres (cm)
+
- the last parameter (optional) is the coordinate unit: in points (for a resolution of 96dpi) by default, in millimeters (mm), in inches (in) or in centimeters (cm)
  
===Export des index et de leurs valeurs===
 
  
Le principe est la création d’un fichier d’index à partir d’un document en vue de son archivage dans un logiciel tiers.
+
===Export of indexes and their values===
Les fichiers d’index produits en standard par ONYX Server peuvent être au format TXT, XML, ou IND (compatible avec Content Manager).
 
Cet export des index dans un fichier est commandé par le commutateur '''-indexfile:xxx'''. L’extension du fichier d’export pilote son type.
 
  
Le paramètre <code>-duplicateindex</code> permet d’exporter également les index dont la valeur est la même sur plusieurs pages.
+
The principle is the creation of an index file from a document with a view to archiving it in third-party software.
 +
The index files produced as standard by ONYX Server can be in TXT, XML, or IND format (compatible with Content Manager).
 +
This export of indexes to a file is controlled by the '''-indexfile:xxx''' switch. The extension of the export file controls its type.
  
Le paramètre <code>-exportemptyindex</code> permet d’exporter également les index qui n’ont pas de valeur.
+
The <code>-duplicateindex</code> parameter allows you to also export indexes whose value is the same on several pages.
  
  
Exemples :
+
The <code>-exportemptyindex</code> parameter allows you to also export indexes that have no value.
 +
 
 +
 
 +
 
 +
Examples:
 
  map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.txt [-duplicateindex] [-exportemptyindex]
 
  map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.txt [-duplicateindex] [-exportemptyindex]
  
Ligne 140 : Ligne 161 :
 
  map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.ind [-duplicateindex] [-exportemptyindex]
 
  map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.ind [-duplicateindex] [-exportemptyindex]
  
==Traitements sur les index==
 
  
===Tri===
+
==Processing on indexes==
  
Le principe est de trier (commutateur '''-sort:xxx''') un document XPS suivant les valeurs d’un ou plusieurs critères d’indexation. Un seul fichier sera créé en sortie. Le tri s’effectue par ordre croissant sur des valeurs numériques par défaut. L’utilisation de l’option ALPHA permet de réaliser un tri sur des valeurs alphanumériques, l’option REVERSE permet un tri par ordre décroissant.
+
===Sorting===
  
 +
The principle is to sort ('''-sort:xxx''' switch) an XPS document according to the values ​​of one or more indexing criteria. Only one file will be created as output. Sorting is done in ascending order using numeric values ​​by default. Using the ALPHA option allows you to sort on alphanumeric values, the REVERSE option allows you to sort in descending order.
  
Exemples :
+
 
 +
Examples :
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -sort:CustomerID -toPDF
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -sort:CustomerID -toPDF
  
Ligne 157 : Ligne 179 :
  
  
===Éclatement===
+
===Spliting===
  
Le principe est d’éclater un document suivant les valeurs d’un ou plusieurs critères d’indexation. Autant de fichiers peuvent être créés en sortie qu’il y a de valeurs différentes du ou des critères utilisés.
 
Ici, pas de commutateur particulier, mais une syntaxe précise à respecter pour commander l’éclatement : <nowiki>[[Nom_index]]</nowiki>.
 
  
Exemples :
+
The principle is to split a document according to the values ​​of one or more indexing criteria. As many output files can be created as there are different values ​​of the criteria used.
 +
Here, no particular switch, but a precise syntax to follow to control the splitting: <nowiki>[[Index_Name]]</nowiki>.
 +
 
 +
Examples :
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_<nowiki>[[CustomerID]]</nowiki>.pdf -toPDF
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_<nowiki>[[CustomerID]]</nowiki>.pdf -toPDF
  
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_[<nowiki>[CustomerID]</nowiki>]_<nowiki>[[InvoiceID]]</nowiki>.pdf -toPDF
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_[<nowiki>[CustomerID]</nowiki>]_<nowiki>[[InvoiceID]]</nowiki>.pdf -toPDF
  
===Éclatement volumique===
+
===Volume spliting===
  
Le mode '''BUNDLEONINDEX''' permet de créer des lots en fonction du nombre de pages pour chaque valeur de critère (par exemple : un fichier avec les documents comptant de 1 à 4 pages pour chaque valeur de critère, un fichier pour les documents comptant de 5 à 9 pages, un fichier pour les documents de plus de 10 pages). Il est possible de créer autant de lots que souhaité.
+
The '''BUNDLEONINDEX''' mode allows you to create batches according to the number of pages for each criterion value (for example: a file with documents having 1 to 4 pages for each criterion value, a file for documents of 5 to 9 pages, one file for documents of more than 10 pages). It is possible to create as many batches as desired.
  
  
Exemple :
+
Example :
  
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice<nowiki>_[[BUNDLEONINDEX,MAPSEND,1,5,10]]</nowiki>.pdf -toPDF
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice<nowiki>_[[BUNDLEONINDEX,MAPSEND,1,5,10]]</nowiki>.pdf -toPDF
  
  
En mode '''BUNDLEONINDEX''', l’éclatement peut également se faire suivant un nombre de feuilles (en fonction des informations de recto/verso), la syntaxe devient alors :
+
In '''BUNDLEONINDEX''' mode, splitting can also be done according to a number of sheets (depending on the front/back information), the syntax then becomes:
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice<nowiki>_[[BUNDLEONINDEX=SHEET,MAPSEND,1,5,10]]</nowiki>.pdf -toPDF
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice<nowiki>_[[BUNDLEONINDEX=SHEET,MAPSEND,1,5,10]]</nowiki>.pdf -toPDF
  
===Filtres ou extraction de pages===
 
  
Le principe est d’isoler certaines pages d’un document XPS en fonction des valeurs d’un ou plusieurs critères d’indexation. Cela peut servir notamment pour créer un document en sortie ne concernant que certains clients.
+
===Filters or page extraction===
Le commutateur '''-filter:xxx''' est utilisé dans ce cas. Les opérateurs mathématiques (=, <, >, <=, >=) et logiques (AND, OR) peuvent être employés pour des filtres complexes sans oublier les parenthèses de priorités.
 
  
Exemples :
+
The principle is to isolate certain pages of an XPS document based on the values ​​of one or more indexing criteria. This can be used in particular to create an output document that only concerns certain clients.
 +
The '''-filter:xxx''' switch is used in this case. Mathematical (=, <, >, <=, >=) and logical (AND, OR) operators can be used for complex filters without forgetting priority parentheses.
 +
 
 +
Examples :
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_426.pdf -toPDF -filter:CUSTOMER=426
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_426.pdf -toPDF -filter:CUSTOMER=426
  
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/extract.pdf -toPDF-filter:(CUSTOMER=4026) OR (CUSTOMER=1458) AND (PRICE=15)
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/extract.pdf -toPDF-filter:(CUSTOMER=4026) OR (CUSTOMER=1458) AND (PRICE=15)
  
Cela peut également s’avérer très utile pour n’effectuer des actions que sur certaines pages dépendant de valeurs de critères, notamment la gestion des options de finition (PrintTickets).
+
This can also be very useful for performing actions only on certain pages depending on criteria values, in particular the management of finishing options (PrintTickets).
 +
 
 +
 
 +
Apart from index management, another switch allows you to extract pages from an XPS document: '''-pages:xxx'''. Page values ​​can be defined by:
  
  
Hors gestion des index, un autre commutateur permet d’extraire des pages d’un document XPS : '''-pages:xxx'''. Les valeurs des pages peuvent être définies par :
+
- unit numbers separated by commas: -pages:1,5,6,7,12
  
- des numéros unitaires séparés par des virgules : -pages:1,5,6,7,12
+
- page intervals: -pages:5-7
  
- des intervalles de pages : -pages:5-7
+
- a combination of both: -pages:1.5-7.12
  
- une combinaison des deux : -pages:1,5-7,12
 
  
- le caractère ‘*’ peut être utilisé dans un intervalle pour préciser la fin du document
+
- the character ‘*’ can be used in an interval to specify the end of the document
  
- les pages à extraire peuvent être inscrites dans un fichier texte externe avec la syntaxe : page[CRLF]
 
  
 +
- the pages to extract can be written in an external text file with the syntax: page[CRLF]
  
Exemples :
+
 
 +
Examples :
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -pages:1,5,6,7,12 -toPDF
 
  map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -pages:1,5,6,7,12 -toPDF
  
Ligne 216 : Ligne 243 :
  
  
==Concaténation de documents==
 
  
Le principe est d’ajouter plusieurs documents les uns à la suite des autres. Le document de sortie est la concaténation de tous les fichiers précisés sur la ligne de commande dans l’ordre où ils ont été précisés.  
+
==Document concatenation==
Deux commutateurs peuvent être utilisés : '''-add:xxx''' (=concaténation de plusieurs documents XPS en un XPS mono document) ou '''-adddoc:xxx''' (=concaténation de plusieurs documents XPS en un XPS multi documents avec conservation des options de finition de chaque document d’origine).
+
 
 +
The principle is to add several documents one after the other. The output document is the concatenation of all the files specified on the command line in the order in which they were specified.  
 +
Two switches can be used: '''-add:xxx''' (=concatenation of several XPS documents into a single XPS document) or '''-adddoc:xxx''' (=concatenation of several XPS documents into an XPS multi documents with preservation of the finishing options of each original document).
  
  
Remarque:
+
Noticed:
On peut ensuite imaginer un tri suivant des critères d’indexation préalablement définis sur chaque fichier pour faire du regroupement de fichiers de plusieurs sources différentes (facture + CGV + lettre d’information…)
+
We can then imagine sorting according to indexing criteria previously defined on each file to group together files from several different sources (invoice + T&Cs + newsletter, etc.)
  
  
Exemples :
+
Examples :
  
Concaténation de plusieurs fichiers XPS en une seule fois :
+
Concatenating multiple XPS files at once:
 
  map_xps -outfile:/tmp/final.xps -add:/tmp/test1.xps -add:/tmp/test2.xps -add:/tmp/test3.xps
 
  map_xps -outfile:/tmp/final.xps -add:/tmp/test1.xps -add:/tmp/test2.xps -add:/tmp/test3.xps
  
  
Concaténation en plusieurs fois, dans le cas où l’on ne connait pas d’avance le nombre de fichiers XPS en entrée (généralement dans une boucle) :
+
Concatenation in several times, in the case where we do not know in advance the number of input XPS files (generally in a loop):
 
  map_xps -tempfile:/tmp/final.xps -add:/tmp/test1.xps
 
  map_xps -tempfile:/tmp/final.xps -add:/tmp/test1.xps
  

Version actuelle datée du 2 janvier 2025 à 16:17

Autres langues :
English • ‎français

List of indexes and their values

The -dumpIndex toggle allows you to list all the indexing criteria present in the XPS document.


Example:

map_xps -infile:/tmp/invoice.xps -dumpIndex
CustomerID
InvoiceID
InvoiceDate
CustomerName
MAPSUBJCT
MAPSEND
NUMPING

Used with the name of a particular index, it lists all the different values ​​of this index:

map_xps -infile:/tmp/invoice.xps -dumpIndex:CustomerID
10638
4274
11426
4533
...


By adding the -duplicateindex switch, the index values ​​are listed on all pages of the XPS document including those with the same value:

map_xps -infile:/tmp/invoice.xps -dumpIndex:CustomerID -duplicateindex
10638
4274
11426
11426
4533
4533
...

Indexing a document

Replications of index values

In certain cases, it may be that an indexing criterion is present on all pages but without a defined value for certain pages or that the indexing criterion is not present on all pages. The copyEmptyIndex switch then allows you to reindex the document by copying, for pages without an index value, the index value found on the previous page.


Example :

map_xps -infile:/tmp/invoice.xps -copyEmptyIndex:InvoiceID

Indexing the file before placing the order:

Page Index Index value
1 InvoiceID 1
2 Cell text
3 InvoiceID 2
4 InvoiceID 3
5 InvoiceID Cell text


Indexing the file after placing the order:

Page Index Valeur de l’index
1 InvoiceID 1
2 InvoiceID 1
3 InvoiceID 2
4 InvoiceID 3
5 InvoiceID 3


Addition of indexing criteria (Static)

The -addCriteria switch allows you to add one or more criteria to a document. The general syntax is:

-addCriteria:IndexName=value


Example: adding one or more indexes with the same value on all pages

map_xps -infile:/tmp/in.xps -outfile:/tmp/out.xps -addCriteria:NumOrder=123456 -addCriteria:Date=17.02.2015


Addition of indexing criteria (Dynamic)

More generally, the values ​​of the added index will come from a prior extraction of text information contained in the XPS document itself on each of its pages. This information, temporarily stored in a /tmp/values.txt file, is reused to add the criterion with the following syntax:


map_xps "-infile:/tmp/in.xps" "-outfile:/tmp/out.xps" "-addCriteria:NumOrder=FILE:/tmp/value.txt"

Extracting criterion values

The principle is to search for information contained in the document and extract it (-extract:xxx switch) into a temporary file and then add them as values ​​of an indexing criterion of the same document. The temporary file created is in text format, in Unicode, with the following syntax: "value[TAB]page[CRLF]". The collection of information in the document can be done by keyword (-filter:xxx switch) or by position (-box:xxx switch). The returned information can be cleaned of extraneous spaces before and/or after the text with the following switches:

-ltrim: removing spaces before the text


-rtrim: removing spaces after the text


-trim: removal of spaces before and after the text

Example 1: Keyword search

map_xps "-infile:/tmp/invoice.xps" "-extract:/tmp/values.txt" "-filter:Invoice for order" "-length:10" "-shift:2" "-rtrim"

⇒ extraction of 10 characters located two characters after the keyword Invoice for order by removing unnecessary spaces after the returned text.

Example 2: search by position

map_xps "-infile:/tmp/invoice.xps" "-extract:/tmp/values.txt" "-box:100,150,180,30,mm"


The box parameters specify its dimensions: xx.xx,xx.xx,xx.xx,xx.xx[,cm|in|mm]


- four decimal numbers specifying in order: top, bottom, left, right


- the decimal separator is ‘.’


- the value separator is ‘,’ or ‘;’


- the last parameter (optional) is the coordinate unit: in points (for a resolution of 96dpi) by default, in millimeters (mm), in inches (in) or in centimeters (cm)


Export of indexes and their values

The principle is the creation of an index file from a document with a view to archiving it in third-party software. The index files produced as standard by ONYX Server can be in TXT, XML, or IND format (compatible with Content Manager). This export of indexes to a file is controlled by the -indexfile:xxx switch. The extension of the export file controls its type.

The -duplicateindex parameter allows you to also export indexes whose value is the same on several pages.


The -exportemptyindex parameter allows you to also export indexes that have no value.


Examples:

map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.txt [-duplicateindex] [-exportemptyindex]
map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.xml [-duplicateindex] [-exportemptyindex]
map_xps -infile:/tmp/invoice.xps -indexfile:/tmp/file.ind [-duplicateindex] [-exportemptyindex]


Processing on indexes

Sorting

The principle is to sort (-sort:xxx switch) an XPS document according to the values ​​of one or more indexing criteria. Only one file will be created as output. Sorting is done in ascending order using numeric values ​​by default. Using the ALPHA option allows you to sort on alphanumeric values, the REVERSE option allows you to sort in descending order.


Examples :

map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -sort:CustomerID -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -sort:ALPHA:CustomerName -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -sort:CustomerID,InvoiceID -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -sort:ALPHA:CustomerName,REVERSE:InvoiceID -toPDF


Spliting

The principle is to split a document according to the values ​​of one or more indexing criteria. As many output files can be created as there are different values ​​of the criteria used. Here, no particular switch, but a precise syntax to follow to control the splitting: [[Index_Name]].

Examples :

map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_[[CustomerID]].pdf -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_[[CustomerID]]_[[InvoiceID]].pdf -toPDF

Volume spliting

The BUNDLEONINDEX mode allows you to create batches according to the number of pages for each criterion value (for example: a file with documents having 1 to 4 pages for each criterion value, a file for documents of 5 to 9 pages, one file for documents of more than 10 pages). It is possible to create as many batches as desired.


Example :

map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_[[BUNDLEONINDEX,MAPSEND,1,5,10]].pdf -toPDF


In BUNDLEONINDEX mode, splitting can also be done according to a number of sheets (depending on the front/back information), the syntax then becomes:

map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_[[BUNDLEONINDEX=SHEET,MAPSEND,1,5,10]].pdf -toPDF


Filters or page extraction

The principle is to isolate certain pages of an XPS document based on the values ​​of one or more indexing criteria. This can be used in particular to create an output document that only concerns certain clients. The -filter:xxx switch is used in this case. Mathematical (=, <, >, <=, >=) and logical (AND, OR) operators can be used for complex filters without forgetting priority parentheses.

Examples :

map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice_426.pdf -toPDF -filter:CUSTOMER=426
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/extract.pdf -toPDF-filter:(CUSTOMER=4026) OR (CUSTOMER=1458) AND (PRICE=15)

This can also be very useful for performing actions only on certain pages depending on criteria values, in particular the management of finishing options (PrintTickets).


Apart from index management, another switch allows you to extract pages from an XPS document: -pages:xxx. Page values ​​can be defined by:


- unit numbers separated by commas: -pages:1,5,6,7,12

- page intervals: -pages:5-7

- a combination of both: -pages:1.5-7.12


- the character ‘*’ can be used in an interval to specify the end of the document


- the pages to extract can be written in an external text file with the syntax: page[CRLF]


Examples :

map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -pages:1,5,6,7,12 -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -pages:5-7 -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -pages:1,5-7,10-* -toPDF
map_xps -infile:/tmp/invoice.xps -outfile:/tmp/invoice.pdf -pages:FILE:/home/extern/pages.txt -toPDF


Document concatenation

The principle is to add several documents one after the other. The output document is the concatenation of all the files specified on the command line in the order in which they were specified. Two switches can be used: -add:xxx (=concatenation of several XPS documents into a single XPS document) or -adddoc:xxx (=concatenation of several XPS documents into an XPS multi documents with preservation of the finishing options of each original document).


Noticed: We can then imagine sorting according to indexing criteria previously defined on each file to group together files from several different sources (invoice + T&Cs + newsletter, etc.)


Examples :

Concatenating multiple XPS files at once:

map_xps -outfile:/tmp/final.xps -add:/tmp/test1.xps -add:/tmp/test2.xps -add:/tmp/test3.xps


Concatenation in several times, in the case where we do not know in advance the number of input XPS files (generally in a loop):

map_xps -tempfile:/tmp/final.xps -add:/tmp/test1.xps
map_xps -tempfile:/tmp/final.xps -add:/tmp/test2.xps
map_xps -tempfile:/tmp/final.xps -add:/tmp/test3.xps