Funzioni di utilità

s

s o seq genera una lista di nomi di variabili. Il carattere # [1], se presente, viene sostituito dal numero della sequenza. E’ possibile utilizzare interi (10), range (2..7), vettori (1,3,5,7,9). Un numero negativo esclude l’elemento dalla sequenza. Eventuali elementi non numerici ('net_2') vengono inseriti come sono. Se tutti gli elementi sono stringhe, verranno sostituiti al carattere #. Specificando solo la radice del nome, vengono restituiti i nomi di variabili presenti nel file di dati che iniziano con quei caratteri. Un numero negativo esclude l’elemento dalla sequenza. true come secondo argomento, esegue il padding con lo zero.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
 s(string, sequences/ranges/values/names)
 s(string, padding, sequences/ranges/values/names)
 s([pre,post], padding, sequences/ranges/values/names)

 s(:x_, 5)                            # => [:x_1, :x_2, :x_3, :x_4, :x_5]
 s(:d2_1_,1..4)                       # => [:d2_1_1, :d2_1_2, :d2_1_3, :d2_1_4] (numero sequenza in fondo)
 s("d2_#_1",1..4)                     # => [:d2_1_1, :d2_2_1, :d2_3_1, :d2_4_1] (numero sequenza interno)
 s(:x_,99,98,7..10,1..3)              # => [:x_99, :x_98, :x_7, :x_8, :x_9, :x_10, :x_1, :x_2, :x_3]
 s(:x_, true, 7..10)                  # => [:x_07, :x_08, :x_09, :x_10]
 s(:x1_, 1..7,-4,-6)                  # => [:x1_1, :x1_2, :x1_3, :x1_5, :x1_7]
 s(:q, 1..7,-6..-4)                   # => [:q1, :q2, :q3, :q7]
 s(:x, 1..3,:net1,4..7,'net_2',99)    # => [:x1, :x2, :x3, :net1, :x4, :x5, :x6,: x7, :net_2 :x99]
 s(:x, ["1","2","3a","3b","4"])       # => [:x1, :x2, :x3a, :x3b, :x4]
 s([:v,'_1'], 101..104,199)           # => [:v101_1, :v102_1, :v103_1, :v104_1, :v199_1]
 s('v#_1', 101..104,199)              # => [:v101_1, :v102_1, :v103_1, :v104_1, :v199_1]

 s(:v10_)                             # => ricerca automatica delle variabili nel file di dati
 s(:v10_,:a)                          # => ricerca automatica con ordinamento alfabetico

s permette anche di generare sequenze numeriche.

1
2
 s(5)         # => [1,2,3,4,5]
 s(3..9)      # => [3,4,5,6,7,8,9]

ss

ss o sseq genera una lista di liste (matrice) di nomi di variabili. Specificare una stringa contentente i nome della variabile con i segnaposti #1 e #2 che verranno sotituiti dalle due sequenze numeriche. E’ possibile utilizzare interi (10), range (2..7), vettori ([1,3,5,7,9]). Un numero negativo esclude l’elemento dalla sequenza. Se si utilizza un elemento composito, passare tutto l’argomento come vettore: [true,2..7,-5,-6]. true come secondo argomento, esegue il padding con lo zero. Se lo zero deve essere aggiunto a una sola sequenza, specificare true come primo elemento dell’argomento.

La funzione è utile per generare le liste di variabili nelle tabelle grid.

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
 ss(string, sequences/ranges/values, sequences/ranges/values)
 ss(string, padding, sequences/ranges/values, sequences/ranges/values)
 ss(string, [padding, sequences/ranges/values], [padding, sequences/ranges/values])

 ss("x1_#1_#2",3,5)                   # => [[:x1_1_1, :x1_1_2, :x1_1_3, :x1_1_4, :x1_1_5], [:x1_2_1, :x1_2_2, :x1_2_3, :x1_2_4, ...]]
 ss("x1_#2_#1",3,5)                   # => [[:x1_1_1, :x1_2_1, :x1_3_1, :x1_4_1, :x1_5_1], [:x1_1_2, :x1_2_2, :x1_3_2, :x1_4_2, ...]]
 ss("x1_#2_#1",3,2..7)                # => [[:x1_2_1, :x1_3_1, :x1_4_1, :x1_5_1, :x1_6_1, :x1_7_1], [:x1_2_2, :x1_3_2, :x1_4_2, ...]]
 ss("x1_#1_#2",[1,3,5,7,9],3)         # => [[:x1_1_1, :x1_1_2, :x1_1_3], [:x1_3_1, :x1_3_2, :x1_3_3], [:x1_5_1, :x1_5_2, ...]]
 ss("x1_#2_#1",3,[2..7,-5,-6])        # => [[:x1_2_1, :x1_3_1, :x1_4_1, :x1_7_1], [:x1_2_2, :x1_3_2, :x1_4_2, :x1_7_2], [:x1_2_3, ...]]
 ss("x1_#2_#1",true,9..12,7..10)      # => [[:x1_07_09, :x1_08_09, :x1_09_09, :x1_10_09], [:x1_07_10, :x1_08_10, :x1_09_10, ...]]
 ss("x1_#2_#1",9..12,[true,7..10])    # => [[:x1_07_9, :x1_08_9, :x1_09_9, :x1_10_9], [:x1_07_10, :x1_08_10, :x1_09_10, ...]]

to

to restituisce l’elenco dei nomi di variabile tra la prima e l’ultima variabile indicata

1
2
3
4
5
 to(:d30, :d38) # dalla variabile d30 alla d38
 to(:d30)       # dalla variabile d30 fino all'ultima
 to(nil, :d38)  # dalla prima variabile fino alla d38

 :d30.to(:d38)  # anche come metodo di Symbol

like

like restituisce l’elenco dei nomi di variabile che corrispondono all’espressione regolare specificata.

1
2
3
 md like(/^v10013_\d+/)

 levels like(/v10180_/) => ["1 per niente d’accordo", "2", "3", "4", "5 completamente d’accordo"]

inc

L’istruzione inc{filename} include il contenuto di un file nello script. Il codice contenuto nel file che viene incluso, viene eseguito come se fosse stato scritto nello stesso punto dell’istruzione inc. L’estensione di default è pt2.

1
2
   inc{"filename"}
   inc{"folder/filename.rb"}

rep

rep cicla [2] sugli elementi di un array (vettore), di un range o di un hash (array associativo). Esegue il codice contenuto nel blocco passando due argomenti: l’elemento e il suo indice. Per gli hash passa tre argomenti: la chiave, il valore e l’indice. L’indice parte da 1. L’indice può essere tralasciato se non serve. I nomi dei parametri sono arbitrari.

 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
 # array generato dalla funzione s con indice
 s(:q25_,1..10).rep do |v, i|
   levels v => {1 => "Voto: 1", 10 => "Voto: 10"}
   ord v, "25.#{i}. Per ciascuno ambito dia un giudizio con un voto da 1 a 10\n$vl()"
 end

 # array generato dalla funzione s senza indice
 s(:q31_,1..10).rep do |var|
   levels var => {1 => "Voto: 1", 10 => "Voto: 10"}
 end

 # array di label con indice
 [ "Scuola",
   "Sanita'",
   "Sicurezza",
   "Sviluppo economico",
   "Politica estera",
   "Giustizia",
   "Fisco",
   "Famiglia",
   "Ambiente",
   "Costi della politica" ].rep do |lab, index|
     label "x40.#{index}" => lab
 end

 # range (su una sola riga)
 (1..18).rep { |n| rename s("q9pr_loop_#{n}_q9pr_resp",9) => s("q9_#{n}_",9) }

 # hash con indice
 { 2 => "Brand X",
   5 => "Brand Y",
   6 => "Brand Z" }.rep do |num, label, index|
   cat "q5pr_loop_#{num}_q5pr_resp", "Q5.#{index} BRAND CONSIDERATION - #{label}"
 end

each

each cicla sugli elementi di un array (vettore), di un range o di un hash (array associativo). Esegue il codice contenuto nel blocco passando come argomento l’elemento. Per gli hash passa due argomenti: la chiave e il valore. I nomi dei parametri sono arbitrari.

each_with_index

each_with_index cicla sugli elementi di un array (vettore), di un range o di un hash (array associativo). Esegue il codice contenuto nel blocco passando due argomenti: l’elemento e il suo indice. Per gli hash passa tre argomenti: la chiave, il valore e l’indice. L’indice parte da 0. I nomi dei parametri sono arbitrari.

eachvars

eachvars cicla sui nomi di variabili del dataset attivo.

1
2
3
eachvars do |var|
  label var => get_label(var).strip_tags
end

.order

Il metodo order applicato a un elenco (Array) di nomi variabil, restituisce l’elenco ordinato rispetto alle ultime cifre del nome della variabile.

1
2
 like("d7_").order
 # => ["d7_1", "d7_2", "d7_3", "d7_4", "d7_5", "d7_6", "d7_7", "d7_8", "d7_9", "d7_10", "d7_99"]

.sample

Il metodo sample applicato a un Array, estrae casualmente un elemento o il numero di elementi indicato.

1
2
3
(1..1000).to_a.sample    # => 973

(1..1000).to_a.sample(5) # => [106, 462, 936, 443, 286]

sortvars

La funzione sortvars applicata a un elenco di variabili, restituisce lo stesso elenco di variabili ordinato in base alla frequenza. Tiene conto di un eventaule filtro attivo.

  • :code => 1: codice da considerare nel conteggio (default 1)
  • :ord => :a|:d: direzione dell’ordinamento :a ascendente, :d discendente (default :d)
1
sortvars(s(:d7_,1..10))

.strip_tags

Il metodo strip_tags applicato a una stringa elimina i tag html.

1
 label :v1 => get_label(:v1).strip_tags

srand

srand inizializza il generatore di numeri pseudo-casuale del sistema con il valore indicato. Può essere utilizzato per garantire sequenze ripetibili di numeri pseudo-casuali tra diverse esecuzioni del programma. Impostando il seme su un valore noto, i programmi possono essere resi deterministici. Restituisce il valore del seme precedente.

1
srand 123456789

stop, stoph, stoph!, stopx, stopx!

  • stop arresta l’esecuzione dello script
  • stoph genera un report HTML e arresta l’esecuzione dello script
  • stoph! genera un report HTML, lo apre e arresta l’esecuzione dello script
  • stopx genera un report XLSX e arresta l’esecuzione dello script
  • stopx! genera un report XLSX, lo apre e arresta l’esecuzione dello script

Eventuali istruzioni successive nello script devono comunque essere sintatticamente corrette.

msg, todo, warn, err, msg!, todo!, warn!

msg, todo, warn e err stampano nell’output i testo che li segue. err causa l’interruzione dello script.

Le varianti msg!, todo!, warn! aprono anche una finestra di dialoco.

Il parametro :nodlg => false non fa comparire la finestra di dialogo.

1
warn "Attenzione controlla il filtro!"
_images/warn1.png
1
warn! "Attenzione controlla il filtro!"
_images/warn2.png

ask

ask genera una finestra di dialogo con i pulsanti indicati oltre al pulsante Stop script. Restituisce il codice associato al pulsante.

I pulsanti devono essere indicati tramite un Hash con le coppie codice/etichetta (default 1 => "Yes", 2 => "No").

Argomenti:

  • question: il testo della finestra
  • {}||[]: un hash con le due coppie codice => etichetta per i pulsanti o un array di valori, in tal caso il codice sarà uguale all’etichetta
1
filter :user => 1 if ask("Devo selezionare solo gli utenti?")
_images/ask1.png
1
ask("Seleziona il sample", (1..7).to_a)
_images/ask2.png
1
ask!("Quale paese vuoi selezionare?", {1 => "Italia", 2 => "Spagna", 3 => "Francia", 4 => "Germania", 5 => "Portogallo" })
_images/ask3.png

input

input genera una finestra di dialogo per l’inserimento di un parametro da parte dell’utente. Se non viene specificato :to_vector o :to_i, il parametro inserito viene restituito come stringa.

Argomenti:

  • question: il testo della finestra
  • :default => value: il valore di default
  • :to_vector => true|false: true genera un vettore separando la stringa di dati inseriti in base alle virgole (default false)
  • :to_i => true|false: true converte i dati inseriti in numero intero (default false)
1
2
filename = input("Digitare il nome del file con i dati da elaborare")
xlsx.open filename
_images/input.png

$x1, $x2, $x3, $x4

All’interno dello script è possibile utilizzare i parametri $x1, $x2, $x3 e $x4. Dopo aver aperto uno scipt di pTabs2 in SciTE Shift-F8 (Maiusc-F8) apre una finestra di dialogo che permette l’inserimento di parametri. I parametri verranno inseriti sulla linea di comando che esegue pTabs2.

_images/scite_parameters.png

Chiudendo la maschera con Set i parametri verranno memorizzati e si potrà eseguire lo script. Il pulsante F5 è comunque disponibile anche con la maschera aperta; in questo modo è possibile cambiare i parametri e immediatamente eseguire lo script.

  • I parametri devono essere inseriti senza utilizzare spazi, altrimenti ogni spazio determina la creazione di un nuovo parametro (anche oltre il quarto). Si può sfruttare questa caratterisitca per creare più di quattro parametri.
  • Per etichette e testi contenenti spazi utilizzare le virgolette.
  • Lasciando un parametro vuoto, il successivo prenderà il posto del precedente.
_images/scite_parameters2.png

fields.to_ptabs_labels

fields.to_ptabs_labels stampa nella finestra di log le istruzioni di pTabs per etichettare le variabili del file di dati.

Argomenti:

  • :vars => [varlist]: elenco delle variabili, se omesso stampa tutte le etichette
  • :ptabs => 1|2: stampa le istruzioni con la sintassi di pTabs2 (2, il default) o della vecchia versione di pTabs (1)
  • :labels => true|false: stampa le istruzioni per le etichette delle variabili (true, il default)
  • :levels => true|false: stampa le istruzioni per le etichette dei valori (true, il default)

fields.to_spss_labels

fields.to_spss_labels stampa nella finestra di log le istruzioni SPSS per etichettare le variabili del file di dati.

Argomenti:

  • :vars => [varlist]: elenco delle variabili, se omesso stampa tutte le etichette
  • :by_val => true|false: stampa le istruzioni variabile per variabile alternando variables labels e values labels (true) oppure un’unica istruzione variables labels per tutte le variabilie seguita da un’istruzione values labels (false, il default)
  • :labels => true|false: stampa le istruzioni per le etichette delle variabili (true, il default)
  • :levels => true|false: stampa le istruzioni per le etichette dei valori (true, il default)

css

L’output HTML e PDF sono controllati da fogli stile CSS. L’utente può ridefinire i propri fogli stile, ma per operazioni più veloci e/o temporanee di modifica degli stili è possibile inserire delle istruzioni css direttamente nello script tramite l’istruzione css.

1
2
3
4
 # disattiva gli stili dei NET
 css << "table td.net { font-weight: normal; }"
 css << "table td.lev1, table td.lev2, table td.lev3 { font-style: normal; }"
 css << "table td.label.lev1, table td.label.lev2, table td.label.lev3 { padding-left: 6px; }"

css.load

pTabs carica automaticamente i fogli stili con i nomi definiti nei parametri di configurazione. I file vengono cercati nella cartella di installazione di pTabs, nella cartella dell’utente e nella cartella di lavoro.

Con l’istruzione css.load(filename) è inoltre possibile caricare degli ulteriori fogli stile css nello script.

1
css.load 'my_syle.css'

debug

debug stampa nel log il contenuto di una variabile, di un oggetto o il valore di ritorno di un metodo.

1
2
 x = 'info'.yload
 debug x

ruler

ruler stampa nel log un righello.

Argomenti:

  • lenght: la lunghezza del righello (default: 100)
  • start: il punto di inizio (default: 1)
  • :off => n: il numero di caratteri da saltare all’inizio della riga (default: 0)
1
ruler 54
         1         2         3         4         5
123456789012345678901234567890123456789012345678901234

Note

[1]I caratteri # e . possono essere utilizzati solo nelle stringhe, non nei simboli. Il carattere # non è un carattere valido nei nomi di variabile. Se presente nel file originale, viene convertito in . o _ a secondo delle impostazioni di dot_to_underscore e underscore_to_dot.
[2]Un ciclo di ripetizioni può comunque essere realizzato utilizzando uno qualsiasi dei costrutti che mette a disposizione Ruby. Ricordarsi comunque che gli indici in Ruby partodo da 0. rep equivale al metodo each_with_index della classe Array con l’indice incrementato di 1.