Ruby - Guida rapida
Ruby è un puro linguaggio di programmazione orientato agli oggetti. È stato creato nel 1993 dal giapponese Yukihiro Matsumoto.
Puoi trovare il nome Yukihiro Matsumoto sulla mailing list di Ruby su www.ruby-lang.org . Matsumoto è anche conosciuto come Matz nella comunità Ruby.
Ruby is "A Programmer's Best Friend".
Ruby ha caratteristiche simili a quelle di Smalltalk, Perl e Python. Perl, Python e Smalltalk sono linguaggi di scripting. Smalltalk è un vero linguaggio orientato agli oggetti. Ruby, come Smalltalk, è un perfetto linguaggio orientato agli oggetti. Usare la sintassi di Ruby è molto più semplice che usare la sintassi di Smalltalk.
Caratteristiche di Ruby
Ruby è un open-source ed è disponibile gratuitamente sul Web, ma è soggetto a licenza.
Ruby è un linguaggio di programmazione interpretato per scopi generali.
Ruby è un vero linguaggio di programmazione orientato agli oggetti.
Ruby è un linguaggio di scripting lato server simile a Python e PERL.
Ruby può essere utilizzato per scrivere script CGI (Common Gateway Interface).
Ruby può essere incorporato in Hypertext Markup Language (HTML).
Ruby ha una sintassi chiara e semplice che consente a un nuovo sviluppatore di apprendere molto rapidamente e facilmente.
Ruby ha una sintassi simile a quella di molti linguaggi di programmazione come C ++ e Perl.
Ruby è molto scalabile e grandi programmi scritti in Ruby sono facilmente gestibili.
Ruby può essere utilizzato per lo sviluppo di applicazioni Internet e intranet.
Ruby può essere installato in ambienti Windows e POSIX.
Ruby supporta molti strumenti GUI come Tcl / Tk, GTK e OpenGL.
Ruby può essere facilmente connesso a DB2, MySQL, Oracle e Sybase.
Ruby ha un ricco set di funzioni integrate, che possono essere utilizzate direttamente negli script Ruby.
Strumenti di cui avrai bisogno
Per eseguire gli esempi discussi in questo tutorial, avrai bisogno di un computer più recente come Intel Core i3 o i5 con un minimo di 2 GB di RAM (4 GB di RAM consigliati). Avrai anche bisogno del seguente software:
Sistema operativo Linux o Windows 95/98/2000 / NT o Windows 7.
Server Web Apache 1.3.19-5.
Browser Web Internet Explorer 5.0 o superiore.
Ruby 1.8.5
Questo tutorial fornirà le competenze necessarie per creare GUI, networking e applicazioni Web utilizzando Ruby. Inoltre parlerà dell'estensione e dell'incorporamento delle applicazioni Ruby.
Cosa c'è dopo?
Il prossimo capitolo ti guida dove puoi ottenere Ruby e la sua documentazione. Infine, ti istruisce su come installare Ruby e preparare un ambiente per sviluppare applicazioni Ruby.
Configurazione dell'ambiente locale
Se sei ancora disposto a configurare il tuo ambiente per il linguaggio di programmazione Ruby, allora procediamo. Questo tutorial ti insegnerà tutti gli argomenti importanti relativi alla configurazione dell'ambiente. Ti consigliamo di esaminare prima i seguenti argomenti e poi procedere oltre:
Installazione di Ruby su Linux / Unix - Se stai pianificando di avere il tuo ambiente di sviluppo su una macchina Linux / Unix, segui questo capitolo.
Installazione di Ruby su Windows - Se stai pianificando di avere il tuo ambiente di sviluppo su una macchina Windows, segui questo capitolo.
Opzioni della riga di comando di Ruby - Questo capitolo elenca tutte le opzioni della riga di comando, che puoi usare insieme all'interprete Ruby.
Variabili d'ambiente di Ruby - Questo capitolo contiene un elenco di tutte le variabili d'ambiente importanti da impostare per far funzionare Ruby Interpreter.
Editori popolari di Ruby
Per scrivere i tuoi programmi Ruby, avrai bisogno di un editor -
Se stai lavorando su un computer Windows, puoi utilizzare qualsiasi semplice editor di testo come Blocco note o Modifica plus.
VIM (Vi IMproved) è un editor di testo molto semplice. Questo è disponibile su quasi tutte le macchine Unix e ora anche su Windows. Altrimenti, puoi usare il tuo editor vi preferito per scrivere programmi Ruby.
RubyWin è un Ruby Integrated Development Environment (IDE) per Windows.
Ruby Development Environment (RDE) è anche un ottimo IDE per gli utenti di Windows.
Ruby interattivo (IRb)
Interactive Ruby (IRb) fornisce una shell per la sperimentazione. All'interno della shell IRb, è possibile visualizzare immediatamente i risultati dell'espressione, riga per riga.
Questo strumento viene fornito con l'installazione di Ruby, quindi non hai nulla da fare in più per far funzionare IRb.
Basta digitare irb al prompt dei comandi e una sessione Ruby interattiva inizierà come indicato di seguito -
$irb
irb 0.6.1(99/09/16)
irb(main):001:0> def hello
irb(main):002:1> out = "Hello World"
irb(main):003:1> puts out
irb(main):004:1> end
nil
irb(main):005:0> hello
Hello World
nil
irb(main):006:0>
Non preoccuparti di quello che abbiamo fatto qui. Imparerai tutti questi passaggi nei capitoli successivi.
Cosa c'è dopo?
Supponiamo ora che tu abbia un ambiente Ruby funzionante e che tu sia pronto per scrivere il primo programma Ruby. Il prossimo capitolo ti insegnerà come scrivere programmi Ruby.
Scriviamo un semplice programma in ruby. Tutti i file ruby avranno estensione.rb. Quindi, inserisci il seguente codice sorgente in un file test.rb.
#!/usr/bin/ruby -w
puts "Hello, Ruby!";
Qui, abbiamo assunto che tu abbia l'interprete Ruby disponibile nella directory / usr / bin. Ora, prova a eseguire questo programma come segue:
$ ruby test.rb
Questo produrrà il seguente risultato:
Hello, Ruby!
Hai visto un semplice programma Ruby, ora vediamo alcuni concetti di base relativi alla sintassi Ruby.
Spazio vuoto nel programma Ruby
I caratteri di spazi bianchi come spazi e tabulazioni vengono generalmente ignorati nel codice Ruby, tranne quando compaiono nelle stringhe. A volte, tuttavia, vengono utilizzati per interpretare affermazioni ambigue. Interpretazioni di questo tipo producono avvisi quando l'opzione -w è abilitata.
Esempio
a + b is interpreted as a+b ( Here a is a local variable)
a +b is interpreted as a(+b) ( Here a is a method call)
Fine di riga nel programma Ruby
Ruby interpreta il punto e virgola e i caratteri di nuova riga come la fine di un'istruzione. Tuttavia, se Ruby incontra operatori, come +, - o backslash alla fine di una riga, indicano la continuazione di un'istruzione.
Identificatori rubino
Gli identificatori sono nomi di variabili, costanti e metodi. Gli identificatori Ruby fanno distinzione tra maiuscole e minuscole. Significa che Ram e RAM sono due identificatori diversi in Ruby.
I nomi degli identificatori Ruby possono essere costituiti da caratteri alfanumerici e dal carattere di sottolineatura (_).
Parole riservate
Il seguente elenco mostra le parole riservate in Ruby. Queste parole riservate non possono essere utilizzate come nomi di costanti o variabili. Possono, tuttavia, essere usati come nomi di metodo.
INIZIO | fare | Il prossimo | poi |
FINE | altro | zero | vero |
alias | elsif | non | undef |
e | fine | o | salvo che |
inizio | garantire | rifare | fino a |
rompere | falso | salvare | quando |
Astuccio | per | riprova | mentre |
classe | Se | ritorno | mentre |
def | in | se stesso | __FILE__ |
definito? | modulo | super | __LINEA__ |
Qui Documento in Ruby
"Here Document" si riferisce alla creazione di stringhe da più righe. Dopo un << è possibile specificare una stringa o un identificatore per terminare la stringa letterale e tutte le righe che seguono la riga corrente fino al terminatore sono il valore della stringa.
Se il terminatore è tra virgolette, il tipo di virgolette determina il tipo di stringa letterale orientata alla riga. Notare che non deve esserci spazio tra << e il terminatore.
Ecco diversi esempi:
#!/usr/bin/ruby -w
print <<EOF
This is the first way of creating
here document ie. multiple line string.
EOF
print <<"EOF"; # same as above
This is the second way of creating
here document ie. multiple line string.
EOF
print <<`EOC` # execute commands
echo hi there
echo lo there
EOC
print <<"foo", <<"bar" # you can stack them
I said foo.
foo
I said bar.
bar
Questo produrrà il seguente risultato:
This is the first way of creating
her document ie. multiple line string.
This is the second way of creating
her document ie. multiple line string.
hi there
lo there
I said foo.
I said bar.
Ruby BEGIN Statement
Sintassi
BEGIN {
code
}
Dichiara il codice da chiamare prima che il programma venga eseguito.
Esempio
#!/usr/bin/ruby
puts "This is main Ruby Program"
BEGIN {
puts "Initializing Ruby Program"
}
Questo produrrà il seguente risultato:
Initializing Ruby Program
This is main Ruby Program
Dichiarazione Ruby END
Sintassi
END {
code
}
Dichiara il codice da chiamare alla fine del programma.
Esempio
#!/usr/bin/ruby
puts "This is main Ruby Program"
END {
puts "Terminating Ruby Program"
}
BEGIN {
puts "Initializing Ruby Program"
}
Questo produrrà il seguente risultato:
Initializing Ruby Program
This is main Ruby Program
Terminating Ruby Program
Commenti Ruby
Un commento nasconde una riga, parte di una riga o più righe all'interprete Ruby. Puoi usare il carattere cancelletto (#) all'inizio di una riga -
# I am a comment. Just ignore me.
Oppure, un commento può trovarsi sulla stessa riga dopo un'istruzione o un'espressione -
name = "Madisetti" # This is again comment
Puoi commentare più righe come segue:
# This is a comment.
# This is a comment, too.
# This is a comment, too.
# I said that already.
Ecco un'altra forma. Questo commento di blocco nasconde diverse righe dell'interprete con = inizio / = fine -
=begin
This is a comment.
This is a comment, too.
This is a comment, too.
I said that already.
=end
Ruby è un perfetto linguaggio di programmazione orientato agli oggetti. Le caratteristiche del linguaggio di programmazione orientato agli oggetti includono:
- Incapsulamento dei dati
- Astrazione dei dati
- Polymorphism
- Inheritance
Queste caratteristiche sono state discusse nel capitolo Object Oriented Ruby .
Un programma orientato agli oggetti coinvolge classi e oggetti. Una classe è il progetto da cui vengono creati i singoli oggetti. In termini orientati agli oggetti, diciamo che la tua bicicletta è un'istanza della classe di oggetti nota come biciclette.
Prendi l'esempio di qualsiasi veicolo. Comprende le ruote, la potenza e la capacità del serbatoio del carburante o del gas. Queste caratteristiche formano i membri dei dati della classe Veicolo. Puoi differenziare un veicolo dall'altro con l'aiuto di queste caratteristiche.
Un veicolo può anche avere determinate funzioni, come fermarsi, guidare e accelerare. Anche queste funzioni formano i membri dati della classe Veicolo. È quindi possibile definire una classe come una combinazione di caratteristiche e funzioni.
Una classe Veicolo può essere definita come:
Class Vehicle {
Number no_of_wheels
Number horsepower
Characters type_of_tank
Number Capacity
Function speeding {
}
Function driving {
}
Function halting {
}
}
Assegnando valori diversi a questi membri dati, è possibile formare diverse istanze della classe Veicolo. Ad esempio, un aereo ha tre ruote, una potenza di 1.000 cavalli, carburante come tipo di serbatoio e una capacità di 100 litri. Allo stesso modo, un'auto ha quattro ruote, 200 cavalli, gas come il tipo di serbatoio e una capacità di 25 litri.
Definizione di una classe in Ruby
Per implementare la programmazione orientata agli oggetti usando Ruby, devi prima imparare a creare oggetti e classi in Ruby.
Una classe in Ruby inizia sempre con la parola chiave class seguita dal nome della classe. Il nome dovrebbe essere sempre in maiuscolo iniziale. La classe Cliente può essere visualizzata come:
class Customer
end
Si termina una classe utilizzando la parola chiave end . Tutti i membri di dati nella classe si trovano tra la definizione della classe e la parola chiave end .
Variabili in una classe Ruby
Ruby fornisce quattro tipi di variabili:
Local Variables- Le variabili locali sono le variabili definite in un metodo. Le variabili locali non sono disponibili al di fuori del metodo. Vedrai maggiori dettagli sul metodo nel capitolo successivo. Le variabili locali iniziano con una lettera minuscola o _.
Instance Variables- Le variabili di istanza sono disponibili tra i metodi per qualsiasi particolare istanza o oggetto. Ciò significa che le variabili di istanza cambiano da oggetto a oggetto. Le variabili di istanza sono precedute dal segno (@) seguito dal nome della variabile.
Class Variables- Le variabili di classe sono disponibili in diversi oggetti. Una variabile di classe appartiene alla classe ed è una caratteristica di una classe. Sono preceduti dal segno @@ e sono seguiti dal nome della variabile.
Global Variables- Le variabili di classe non sono disponibili tra le classi. Se vuoi avere una singola variabile, che è disponibile tra le classi, devi definire una variabile globale. Le variabili globali sono sempre precedute dal segno del dollaro ($).
Esempio
Utilizzando la variabile di classe @@ no_of_customers, è possibile determinare il numero di oggetti che vengono creati. Ciò consente di derivare il numero di clienti.
class Customer
@@no_of_customers = 0
end
Creazione di oggetti in Ruby utilizzando il nuovo metodo
Gli oggetti sono istanze della classe. Ora imparerai come creare oggetti di una classe in Ruby. Puoi creare oggetti in Ruby usando il metodo new della classe.
Il metodo new è un tipo di metodo unico, predefinito nella libreria Ruby. Il nuovo metodo appartiene ai metodi di classe .
Ecco l'esempio per creare due oggetti cust1 e cust2 della classe Customer:
cust1 = Customer. new
cust2 = Customer. new
Qui, cust1 e cust2 sono i nomi di due oggetti. Scrivi il nome dell'oggetto seguito dal segno di uguale (=) dopo di che seguirà il nome della classe. Quindi seguiranno l'operatore punto e la parola chiave new .
Metodo personalizzato per creare oggetti Ruby
È possibile passare parametri al metodo new e questi parametri possono essere utilizzati per inizializzare le variabili di classe.
Quando si prevede di dichiarare il nuovo metodo con parametri, è necessario dichiarare il metodo inizializzato al momento della creazione della classe.
Il metodo initialize è un tipo speciale di metodo, che verrà eseguito quando il nuovo metodo della classe viene chiamato con parametri.
Ecco l'esempio per creare il metodo di inizializzazione:
class Customer
@@no_of_customers = 0
def initialize(id, name, addr)
@cust_id = id
@cust_name = name
@cust_addr = addr
end
end
In questo esempio, dichiari il metodo di inizializzazione conid, name, e addrcome variabili locali. Qui, DEF e fine vengono utilizzati per definire un metodo di Ruby initialize . Imparerai di più sui metodi nei capitoli successivi.
Nel metodo initialize , trasferisci i valori di queste variabili locali alle variabili di istanza @cust_id, @cust_name e @cust_addr. Qui le variabili locali contengono i valori che vengono passati insieme al nuovo metodo.
Ora puoi creare oggetti come segue:
cust1 = Customer.new("1", "John", "Wisdom Apartments, Ludhiya")
cust2 = Customer.new("2", "Poul", "New Empire road, Khandala")
Funzioni membro nella classe Ruby
In Ruby, le funzioni sono chiamate metodi. Ogni metodo in una classe inizia con la parola chiave def seguita dal nome del metodo.
Il nome del metodo è sempre preferito in lowercase letters. Si termina un metodo in Ruby utilizzando la parola chiave end .
Ecco l'esempio per definire un metodo Ruby:
class Sample
def function
statement 1
statement 2
end
end
Qui, l' istruzione 1 e l' istruzione 2 fanno parte del corpo della funzione del metodo all'interno della classe Sample. Queste affermazioni potrebbero essere qualsiasi dichiarazione Ruby valida. Ad esempio possiamo mettere un metodo put per stampare Hello Ruby come segue:
class Sample
def hello
puts "Hello Ruby!"
end
end
Ora nel seguente esempio, crea un oggetto della classe Sample e chiama il metodo hello e guarda il risultato -
#!/usr/bin/ruby
class Sample
def hello
puts "Hello Ruby!"
end
end
# Now using above class to create objects
object = Sample. new
object.hello
Questo produrrà il seguente risultato:
Hello Ruby!
Case study semplice
Ecco un caso di studio se vuoi fare più pratica con la classe e gli oggetti.
Ruby Class Case Study
Le variabili sono le posizioni di memoria, che contengono tutti i dati che devono essere utilizzati da qualsiasi programma.
Esistono cinque tipi di variabili supportate da Ruby. Hai già esaminato una piccola descrizione di queste variabili anche nel capitolo precedente. Questi cinque tipi di variabili sono spiegati in questo capitolo.
Variabili globali di Ruby
Le variabili globali iniziano con $. Le variabili globali non inizializzate hanno il valore nil e producono avvisi con l'opzione -w.
L'assegnazione a variabili globali altera lo stato globale. Non è consigliabile utilizzare variabili globali. Rendono i programmi criptici.
Di seguito è riportato un esempio che mostra l'utilizzo della variabile globale.
#!/usr/bin/ruby
$global_variable = 10 class Class1 def print_global puts "Global variable in Class1 is #$global_variable"
end
end
class Class2
def print_global
puts "Global variable in Class2 is #$global_variable"
end
end
class1obj = Class1.new
class1obj.print_global
class2obj = Class2.new
class2obj.print_global
Qui $ global_variable è una variabile globale. Questo produrrà il seguente risultato:
NOTE - In Ruby, PUOI accedere al valore di qualsiasi variabile o costante inserendo un carattere cancelletto (#) appena prima di quella variabile o costante.
Global variable in Class1 is 10
Global variable in Class2 is 10
Variabili di istanza di Ruby
Le variabili di istanza iniziano con @. Le variabili di istanza non inizializzate hanno il valore nil e producono avvisi con l'opzione -w.
Di seguito è riportato un esempio che mostra l'utilizzo delle variabili di istanza.
#!/usr/bin/ruby
class Customer
def initialize(id, name, addr)
@cust_id = id
@cust_name = name
@cust_addr = addr
end
def display_details()
puts "Customer id #@cust_id"
puts "Customer name #@cust_name"
puts "Customer address #@cust_addr"
end
end
# Create Objects
cust1 = Customer.new("1", "John", "Wisdom Apartments, Ludhiya")
cust2 = Customer.new("2", "Poul", "New Empire road, Khandala")
# Call Methods
cust1.display_details()
cust2.display_details()
Qui, @cust_id, @cust_name e @cust_addr sono variabili di istanza. Questo produrrà il seguente risultato:
Customer id 1
Customer name John
Customer address Wisdom Apartments, Ludhiya
Customer id 2
Customer name Poul
Customer address New Empire road, Khandala
Variabili di classe Ruby
Le variabili di classe iniziano con @@ e devono essere inizializzate prima di poter essere utilizzate nelle definizioni dei metodi.
Fare riferimento a una variabile di classe non inizializzata produce un errore. Le variabili di classe sono condivise tra i discendenti della classe o del modulo in cui sono definite le variabili di classe.
L'override delle variabili di classe produce avvisi con l'opzione -w.
Ecco un esempio che mostra l'utilizzo della variabile di classe:
#!/usr/bin/ruby
class Customer
@@no_of_customers = 0
def initialize(id, name, addr)
@cust_id = id
@cust_name = name
@cust_addr = addr
end
def display_details()
puts "Customer id #@cust_id"
puts "Customer name #@cust_name"
puts "Customer address #@cust_addr"
end
def total_no_of_customers()
@@no_of_customers += 1
puts "Total number of customers: #@@no_of_customers"
end
end
# Create Objects
cust1 = Customer.new("1", "John", "Wisdom Apartments, Ludhiya")
cust2 = Customer.new("2", "Poul", "New Empire road, Khandala")
# Call Methods
cust1.total_no_of_customers()
cust2.total_no_of_customers()
Qui @@ no_of_customers è una variabile di classe. Questo produrrà il seguente risultato:
Total number of customers: 1
Total number of customers: 2
Variabili locali di Ruby
Le variabili locali iniziano con una lettera minuscola o _. L'ambito di una variabile locale varia da class, module, def o do all'estremità corrispondente o dalla parentesi graffa di apertura di un blocco alla parentesi chiusa {}.
Quando si fa riferimento a una variabile locale non inizializzata, viene interpretata come una chiamata a un metodo che non ha argomenti.
L'assegnazione a variabili locali non inizializzate serve anche come dichiarazione di variabili. Le variabili iniziano a esistere fino a quando non viene raggiunta la fine dell'ambito corrente. La durata delle variabili locali viene determinata quando Ruby analizza il programma.
Nell'esempio precedente, le variabili locali sono id, name e addr.
Costanti di rubino
Le costanti iniziano con una lettera maiuscola. È possibile accedere alle costanti definite all'interno di una classe o di un modulo dall'interno di quella classe o modulo e quelle definite all'esterno di una classe o di un modulo sono accessibili globalmente.
Le costanti potrebbero non essere definite all'interno dei metodi. Fare riferimento a una costante non inizializzata produce un errore. L'esecuzione di un'assegnazione a una costante già inizializzata produce un avviso.
#!/usr/bin/ruby
class Example
VAR1 = 100
VAR2 = 200
def show
puts "Value of first Constant is #{VAR1}"
puts "Value of second Constant is #{VAR2}"
end
end
# Create Objects
object = Example.new()
object.show
Qui VAR1 e VAR2 sono costanti. Questo produrrà il seguente risultato:
Value of first Constant is 100
Value of second Constant is 200
Ruby Pseudo-Variabili
Sono variabili speciali che hanno l'aspetto di variabili locali ma si comportano come costanti. Non è possibile assegnare alcun valore a queste variabili.
self - L'oggetto ricevitore del metodo corrente.
true - Valore che rappresenta vero.
false - Valore che rappresenta falso.
nil - Valore che rappresenta undefined.
__FILE__ - Il nome del file sorgente corrente.
__LINE__ - Il numero di riga corrente nel file di origine.
Ruby Basic Literals
Le regole che Ruby usa per i letterali sono semplici e intuitive. Questa sezione spiega tutti i letterali Ruby di base.
Numeri interi
Ruby supporta i numeri interi. Un numero intero può variare da -2 30 a 2 30-1 o da -2 62 a 2 62-1 . I numeri interi all'interno di questo intervallo sono oggetti della classe Fixnum e gli interi al di fuori di questo intervallo vengono memorizzati negli oggetti della classe Bignum .
Scrivi numeri interi utilizzando un segno iniziale opzionale, un indicatore di base opzionale (0 per ottale, 0x per esadecimale o 0b per binario), seguito da una stringa di cifre nella base appropriata. I caratteri di sottolineatura vengono ignorati nella stringa di cifre.
È anche possibile ottenere il valore intero, corrispondente a un carattere ASCII o eseguire l'escape della sequenza precedendolo con un punto interrogativo.
Esempio
123 # Fixnum decimal
1_234 # Fixnum decimal with underline
-500 # Negative Fixnum
0377 # octal
0xff # hexadecimal
0b1011 # binary
?a # character code for 'a'
?\n # code for a newline (0x0a)
12345678901234567890 # Bignum
NOTE - Le classi e gli oggetti sono spiegati in un capitolo separato di questo tutorial.
Numeri fluttuanti
Ruby supporta i numeri mobili. Sono anche numeri ma con decimali. I numeri in virgola mobile sono oggetti della classe Float e possono essere uno dei seguenti:
Esempio
123.4 # floating point value
1.0e6 # scientific notation
4E20 # dot not required
4e+20 # sign before exponential
Valori letterali stringa
Le stringhe Ruby sono semplicemente sequenze di byte a 8 bit e sono oggetti della classe String. Le stringhe con virgolette doppie consentono la sostituzione e la notazione con barra rovesciata, ma le stringhe con virgolette singole non consentono la sostituzione e consentono la notazione con barra rovesciata solo per \\ e \ '
Esempio
#!/usr/bin/ruby -w
puts 'escape using "\\"';
puts 'That\'s right';
Questo produrrà il seguente risultato:
escape using "\"
That's right
Puoi sostituire il valore di qualsiasi espressione Ruby in una stringa utilizzando la sequenza #{ expr }. Qui, expr potrebbe essere qualsiasi espressione rubino.
#!/usr/bin/ruby -w
puts "Multiplication Value : #{24*60*60}";
Questo produrrà il seguente risultato:
Multiplication Value : 86400
Notazioni con barra rovesciata
Di seguito è riportato l'elenco delle notazioni backslash supportate da Ruby:
Notazione | Carattere rappresentato |
---|---|
\ n | Nuova riga (0x0a) |
\ r | Ritorno a capo (0x0d) |
\ f | Formfeed (0x0c) |
\ b | Backspace (0x08) |
\un | Campana (0x07) |
\ e | Fuga (0x1b) |
\S | Spazio (0x20) |
\ nnn | Notazione ottale (n = 0-7) |
\ xnn | Notazione esadecimale (n è 0-9, af o AF) |
\ cx, \ Cx | Control-x |
\ Mx | Meta-x (c | 0x80) |
\ M- \ Cx | Meta-Control-x |
\X | Carattere x |
Per maggiori dettagli su Ruby Strings, vai su Ruby Strings .
Ruby Arrays
I valori letterali di Ruby Array vengono creati inserendo una serie di riferimenti a oggetti separati da virgole tra parentesi quadre. Una virgola finale viene ignorata.
Esempio
#!/usr/bin/ruby
ary = [ "fred", 10, 3.14, "This is a string", "last element", ]
ary.each do |i|
puts i
end
Questo produrrà il seguente risultato:
fred
10
3.14
This is a string
last element
Per maggiori dettagli su Ruby Arrays, consulta Ruby Arrays .
Ruby Hash
Un Ruby Hash letterale viene creato inserendo un elenco di coppie chiave / valore tra parentesi graffe, con una virgola o la sequenza => tra la chiave e il valore. Una virgola finale viene ignorata.
Esempio
#!/usr/bin/ruby
hsh = colors = { "red" => 0xf00, "green" => 0x0f0, "blue" => 0x00f }
hsh.each do |key, value|
print key, " is ", value, "\n"
end
Questo produrrà il seguente risultato:
red is 3840
green is 240
blue is 15
Per maggiori dettagli su Ruby Hash, consulta Ruby Hash .
Ruby Ranges
Un intervallo rappresenta un intervallo che è un insieme di valori con un inizio e una fine. Gli intervalli possono essere costruiti utilizzando i letterali s..e e s ... e, o con Range.new.
Intervalli costruiti utilizzando .. vanno dall'inizio alla fine in modo inclusivo. Quelli creati utilizzando ... escludono il valore finale. Quando vengono utilizzati come iteratori, gli intervalli restituiscono ogni valore nella sequenza.
Un intervallo (1..5) significa che include 1, 2, 3, 4, 5 valori e un intervallo (1 ... 5) significa che include 1, 2, 3, 4 valori.
Esempio
#!/usr/bin/ruby
(10..15).each do |n|
print n, ' '
end
Questo produrrà il seguente risultato:
10 11 12 13 14 15
Per maggiori dettagli su Ruby Ranges, vai su Ruby Ranges .
Ruby supporta un ricco set di operatori, come ci si aspetterebbe da un linguaggio moderno. La maggior parte degli operatori sono in realtà chiamate a metodi. Ad esempio, a + b viene interpretato come a. + (B), dove il metodo + nell'oggetto a cui fa riferimento la variabile a viene chiamato con b come argomento.
Per ogni operatore (+ - * /% ** & | ^ << >> && ||), esiste una forma corrispondente di operatore di assegnazione abbreviata (+ = - = ecc.).
Operatori aritmetici di Ruby
Supponiamo che la variabile a contenga 10 e la variabile b ne contenga 20, quindi -
Operatore | Descrizione | Esempio |
---|---|---|
+ | Addizione: aggiunge valori su entrambi i lati dell'operatore. | a + b darà 30 |
- | Sottrazione: sottrae l'operando destro dall'operando sinistro. | a - b darà -10 |
* | Moltiplicazione: moltiplica i valori su entrambi i lati dell'operatore. | a * b darà 200 |
/ | Divisione: divide l'operando di sinistra per l'operando di destra. | b / a darà 2 |
% | Modulo: divide l'operando sinistro per l'operando destro e restituisce il resto. | b% a darà 0 |
** | Esponente: esegue il calcolo esponenziale (potenza) sugli operatori. | a ** b darà 10 alla potenza 20 |
Operatori di confronto di Ruby
Supponiamo che la variabile a contenga 10 e la variabile b ne contenga 20, quindi -
Operatore | Descrizione | Esempio |
---|---|---|
== | Controlla se il valore di due operandi è uguale o meno, in caso affermativo la condizione diventa vera. | (a == b) non è vero. |
! = | Controlla se il valore di due operandi è uguale o meno, se i valori non sono uguali la condizione diventa vera. | (a! = b) è vero. |
> | Controlla se il valore dell'operando sinistro è maggiore del valore dell'operando destro, in caso affermativo la condizione diventa vera. | (a> b) non è vero. |
< | Controlla se il valore dell'operando sinistro è inferiore al valore dell'operando destro, in caso affermativo la condizione diventa vera. | (a <b) è vero. |
> = | Controlla se il valore dell'operando sinistro è maggiore o uguale al valore dell'operando destro, in caso affermativo la condizione diventa vera. | (a> = b) non è vero. |
<= | Controlla se il valore dell'operando sinistro è minore o uguale al valore dell'operando destro, in caso affermativo la condizione diventa vera. | (a <= b) è vero. |
<=> | Operatore di confronto combinato. Restituisce 0 se il primo operando è uguale al secondo, 1 se il primo operando è maggiore del secondo e -1 se il primo operando è minore del secondo. | (a <=> b) restituisce -1. |
=== | Utilizzato per testare l'uguaglianza all'interno di una clausola when di un'istruzione case . | (1 ... 10) === 5 restituisce true. |
.eql? | Vero se il destinatario e l'argomento hanno lo stesso tipo e valori uguali. | 1 == 1.0 restituisce vero, ma 1.eql? (1.0) è falso. |
pari? | Vero se il destinatario e l'argomento hanno lo stesso ID oggetto. | se aObj è duplicato di bObj allora aObj == bObj è vero, a.equal? bObj è falso ma a.equal? aObj è vero. |
Operatori di assegnazione Ruby
Supponiamo che la variabile a contenga 10 e la variabile b ne contenga 20, quindi -
Operatore | Descrizione | Esempio |
---|---|---|
= | Operatore di assegnazione semplice, assegna i valori dagli operandi del lato destro all'operando del lato sinistro. | c = a + b assegnerà il valore di a + b in c |
+ = | Aggiungi operatore di assegnazione AND, aggiunge l'operando destro all'operando sinistro e assegna il risultato all'operando sinistro. | c + = a è equivalente a c = c + a |
- = | Sottrai l'operatore di assegnazione AND, sottrae l'operando destro dall'operando sinistro e assegna il risultato all'operando sinistro. | c - = a è equivalente a c = c - a |
* = | Moltiplica l'operatore di assegnazione AND, moltiplica l'operando destro con l'operando sinistro e assegna il risultato all'operando sinistro. | c * = a è equivalente a c = c * a |
/ = | Divide AND operatore di assegnazione, divide l'operando sinistro con l'operando destro e assegna il risultato all'operando sinistro. | c / = a è equivalente a c = c / a |
% = | Modulo AND operatore di assegnazione, accetta il modulo utilizzando due operandi e assegna il risultato all'operando sinistro. | c% = a è equivalente a c = c% a |
** = | Operatore di assegnazione AND esponenziale, esegue il calcolo esponenziale (potenza) sugli operatori e assegna un valore all'operando sinistro. | c ** = a è equivalente a c = c ** a |
Ruby Parallel Assignment
Ruby supporta anche l'assegnazione parallela di variabili. Ciò consente di inizializzare più variabili con una singola riga di codice Ruby. Ad esempio:
a = 10
b = 20
c = 30
Questo può essere dichiarato più rapidamente usando l'assegnazione parallela -
a, b, c = 10, 20, 30
L'assegnazione parallela è utile anche per scambiare i valori contenuti in due variabili:
a, b = b, c
Ruby Bitwise Operators
L'operatore bit per bit lavora sui bit ed esegue l'operazione bit per bit.
Assumiamo se a = 60; e b = 13; ora in formato binario saranno i seguenti -
a = 0011 1100
b = 0000 1101
------------------
a&b = 0000 1100
a|b = 0011 1101
a^b = 0011 0001
~a = 1100 0011
I seguenti operatori bit per bit sono supportati dal linguaggio Ruby.
Operatore | Descrizione | Esempio |
---|---|---|
& | L'operatore AND binario copia un po 'nel risultato se esiste in entrambi gli operandi. | (a & b) darà 12, che è 0000 1100 |
| | L'operatore OR binario copia un bit se esiste in uno degli operandi. | (a | b) darà 61, che è 0011 1101 |
^ | L'operatore XOR binario copia il bit se è impostato in un operando ma non in entrambi. | (a ^ b) darà 49, che è 0011 0001 |
~ | Binary Ones Complement Operator è unario e ha l'effetto di "ribaltare" i bit. | (~ a) darà -61, che è 1100 0011 in forma di complemento a 2 a causa di un numero binario con segno. |
<< | Operatore binario di spostamento sinistro. Il valore dell'operando sinistro viene spostato a sinistra del numero di bit specificato dall'operando destro. | a << 2 darà 240, che è 1111 0000 |
>> | Operatore binario di spostamento a destra. Il valore dell'operando di sinistra viene spostato a destra del numero di bit specificato dall'operando di destra. | a >> 2 darà 15, che è 0000 1111 |
Operatori logici Ruby
I seguenti operatori logici sono supportati dal linguaggio Ruby
Supponiamo che la variabile a contenga 10 e la variabile b ne contenga 20, quindi -
Operatore | Descrizione | Esempio |
---|---|---|
e | Chiamato operatore AND logico. Se entrambi gli operandi sono veri, la condizione diventa vera. | (aeb) è vero. |
o | Chiamato Operatore OR logico. Se uno dei due operandi è diverso da zero, la condizione diventa vera. | (aob) è vero. |
&& | Chiamato operatore AND logico. Se entrambi gli operandi sono diversi da zero, la condizione diventa vera. | (a && b) è vero. |
|| | Chiamato Operatore OR logico. Se uno dei due operandi è diverso da zero, la condizione diventa vera. | (a || b) è vero. |
! | Chiamato operatore NOT logico. Utilizzare per invertire lo stato logico del suo operando. Se una condizione è vera, l'operatore NOT logico la renderà falsa. | ! (a && b) è falso. |
non | Chiamato operatore NOT logico. Utilizzare per invertire lo stato logico del suo operando. Se una condizione è vera, l'operatore NOT logico la renderà falsa. | not (a && b) è falso. |
Ruby Ternary Operator
C'è un altro operatore chiamato Operatore ternario. Prima valuta un'espressione per un valore vero o falso e quindi esegue una delle due istruzioni fornite a seconda del risultato della valutazione. L'operatore condizionale ha questa sintassi:
Operatore | Descrizione | Esempio |
---|---|---|
? : | Espressione condizionale | Se la condizione è vera? Quindi valore X: altrimenti valore Y |
Ruby Range Operators
Gli intervalli di sequenza in Ruby vengono utilizzati per creare un intervallo di valori successivi, costituito da un valore iniziale, un valore finale e un intervallo di valori intermedi.
In Ruby, queste sequenze vengono create utilizzando gli operatori di intervallo ".." e "...". Il modulo a due punti crea un intervallo inclusivo, mentre il modulo a tre punti crea un intervallo che esclude il valore alto specificato.
Operatore | Descrizione | Esempio |
---|---|---|
.. | Crea un intervallo dal punto iniziale al punto finale compreso. | 1..10 Crea un intervallo da 1 a 10 inclusi. |
... | Crea un intervallo dal punto iniziale al punto finale esclusivo. | 1 ... 10 Crea un intervallo da 1 a 9. |
Ruby definito? Operatori
definito? è un operatore speciale che assume la forma di una chiamata al metodo per determinare se l'espressione passata è definita o meno. Restituisce una stringa di descrizione dell'espressione o nil se l'espressione non è definita.
Ci sono vari utilizzi di definiti? Operatore
Utilizzo 1
defined? variable # True if variable is initialized
For Example
foo = 42
defined? foo # => "local-variable"
defined? $_ # => "global-variable"
defined? bar # => nil (undefined)
Utilizzo 2
defined? method_call # True if a method is defined
For Example
defined? puts # => "method"
defined? puts(bar) # => nil (bar is not defined here)
defined? unpack # => nil (not defined here)
Utilizzo 3
# True if a method exists that can be called with super user
defined? super
For Example
defined? super # => "super" (if it can be called)
defined? super # => nil (if it cannot be)
Utilizzo 4
defined? yield # True if a code block has been passed
For Example
defined? yield # => "yield" (if there is a block passed)
defined? yield # => nil (if there is no block)
Ruby Dot "." e Double Colon "::" Operatori
Si chiama un metodo di modulo facendo precedere il suo nome con il nome del modulo e un punto e si fa riferimento a una costante utilizzando il nome del modulo e due due punti.
Il :: è un operatore unario che consente di accedere da qualsiasi punto al di fuori della classe o del modulo: costanti, metodi di istanza e metodi di classe definiti all'interno di una classe o di un modulo.
Remember in Ruby, anche classi e metodi possono essere considerati costanti.
Devi solo aggiungere il prefisso :: Const_name con un'espressione che restituisce la classe o l'oggetto modulo appropriato.
Se non viene utilizzata alcuna espressione di prefisso, per impostazione predefinita viene utilizzata la classe Object principale.
Ecco due esempi:
MR_COUNT = 0 # constant defined on main Object class
module Foo
MR_COUNT = 0
::MR_COUNT = 1 # set global count to 1
MR_COUNT = 2 # set local count to 2
end
puts MR_COUNT # this is the global constant
puts Foo::MR_COUNT # this is the local "Foo" constant
Second Example
CONST = ' out there'
class Inside_one
CONST = proc {' in there'}
def where_is_my_CONST
::CONST + ' inside one'
end
end
class Inside_two
CONST = ' inside two'
def where_is_my_CONST
CONST
end
end
puts Inside_one.new.where_is_my_CONST
puts Inside_two.new.where_is_my_CONST
puts Object::CONST + Inside_two::CONST
puts Inside_two::CONST + CONST
puts Inside_one::CONST
puts Inside_one::CONST.call + Inside_two::CONST
Precedenza degli operatori Ruby
La tabella seguente elenca tutti gli operatori dalla precedenza più alta al più basso.
Metodo | Operatore | Descrizione |
---|---|---|
sì | :: | Operatore a risoluzione costante |
sì | [] [] = | Riferimento elemento, set di elementi |
sì | ** | Esponenziazione (aumento alla potenza) |
sì | ! ~ + - | No, complemento, più e meno unario (i nomi dei metodi per gli ultimi due sono + @ e - @) |
sì | * /% | Moltiplica, dividi e modulo |
sì | + - | Addizione e sottrazione |
sì | >> << | Spostamento bit per bit destro e sinistro |
sì | & | Bitwise "AND" |
sì | ^ | | "OR" esclusivo bit per bit e "OR" regolare |
sì | <= <>> = | Operatori di confronto |
sì | <=> == ===! = = ~! ~ | Uguaglianza e operatori di corrispondenza del modello (! = E! ~ Potrebbero non essere definiti come metodi) |
&& | Logico "AND" | |
|| | "OR" logico | |
.. ... | Gamma (inclusiva ed esclusiva) | |
? : | Ternario se-allora-altro | |
=% = {/ = - = + = | = & = >> = << = * = && = || = ** = | Incarico | |
definito? | Verificare se il simbolo specificato è definito | |
non | Negazione logica | |
o e | Composizione logica |
NOTE- Gli operatori con un Sì nella colonna del metodo sono in realtà metodi e come tali possono essere sovrascritti.
I commenti sono righe di annotazioni all'interno del codice Ruby che vengono ignorate in fase di esecuzione. Un commento a riga singola inizia con il carattere # e si estende da # fino alla fine della riga come segue:
#!/usr/bin/ruby -w
# This is a single line comment.
puts "Hello, Ruby!"
Quando viene eseguito, il programma di cui sopra produce il seguente risultato:
Hello, Ruby!
Commenti su più righe di Ruby
Puoi commentare più righe usando =begin e =end sintassi come segue -
#!/usr/bin/ruby -w
puts "Hello, Ruby!"
=begin
This is a multiline comment and con spwan as many lines as you
like. But =begin and =end should come in the first line only.
=end
Quando viene eseguito, il programma di cui sopra produce il seguente risultato:
Hello, Ruby!
Assicurati che i commenti finali siano abbastanza lontani dal codice e che siano facilmente distinguibili. Se in un blocco esiste più di un commento finale, allinearli. Ad esempio:
@counter # keeps track times page has been hit
@siteCounter # keeps track of times all pages have been hit
Ruby offre strutture condizionali abbastanza comuni ai linguaggi moderni. Qui, spiegheremo tutte le istruzioni condizionali e i modificatori disponibili in Ruby.
Ruby if ... else Statement
Sintassi
if conditional [then]
code...
[elsif conditional [then]
code...]...
[else
code...]
end
se le espressioni vengono utilizzate per l'esecuzione condizionale. I valori false e nil sono false e tutto il resto è vero. Nota che Ruby usa elsif, non else if né elif.
Esegue il codice se il condizionale è vero. Se il condizionale non è vero, viene eseguito il codice specificato nella clausola else.
Il condizionale di un'espressione if è separato dal codice dalla parola riservata then , una nuova riga o un punto e virgola.
Esempio
#!/usr/bin/ruby
x = 1
if x > 2
puts "x is greater than 2"
elsif x <= 2 and x!=0
puts "x is 1"
else
puts "I can't guess the number"
end
x is 1
Rubino se modificatore
Sintassi
code if condition
Esegue il codice se il condizionale è vero.
Esempio
#!/usr/bin/ruby
$debug = 1
print "debug\n" if $debug
Questo produrrà il seguente risultato:
debug
Ruby a meno che Statement
Sintassi
unless conditional [then]
code
[else
code ]
end
Esegue il codice se condizionale è falso. Se il condizionale è vero, viene eseguito il codice specificato nella clausola else.
Esempio
#!/usr/bin/ruby
x = 1
unless x>=2
puts "x is less than 2"
else
puts "x is greater than 2"
end
Questo produrrà il seguente risultato:
x is less than 2
Ruby a meno che non sia modificatore
Sintassi
code unless conditional
Esegue il codice se condizionale è falso.
Esempio
#!/usr/bin/ruby
$var = 1
print "1 -- Value is set\n" if $var print "2 -- Value is set\n" unless $var
$var = false print "3 -- Value is set\n" unless $var
Questo produrrà il seguente risultato:
1 -- Value is set
3 -- Value is set
Dichiarazione sul caso Ruby
Sintassi
case expression
[when expression [, expression ...] [then]
code ]...
[else
code ]
end
Confronta l' espressione specificata da case e quella specificata da quando si utilizza l'operatore === ed esegue il codice della clausola when che corrisponde.
L' espressione specificata dalla clausola when viene valutata come operando sinistro. Se le clausole no when corrispondono, case esegue il codice della clausola else .
A quando l'espressione di dichiarazione è separata dal codice dalla parola riservata quindi, un ritorno a capo, o un punto e virgola. Quindi -
case expr0
when expr1, expr2
stmt1
when expr3, expr4
stmt2
else
stmt3
end
è fondamentalmente simile al seguente:
_tmp = expr0
if expr1 === _tmp || expr2 === _tmp
stmt1
elsif expr3 === _tmp || expr4 === _tmp
stmt2
else
stmt3
end
Esempio
#!/usr/bin/ruby
$age = 5 case $age
when 0 .. 2
puts "baby"
when 3 .. 6
puts "little child"
when 7 .. 12
puts "child"
when 13 .. 18
puts "youth"
else
puts "adult"
end
Questo produrrà il seguente risultato:
little child
I loop in Ruby vengono utilizzati per eseguire lo stesso blocco di codice un numero di volte specificato. Questo capitolo descrive in dettaglio tutte le istruzioni loop supportate da Ruby.
Ruby while Statement
Sintassi
while conditional [do]
code
end
Esegue il codice mentre il condizionale è vero. Un po ' di ciclo condizionale è separato dal codice dalla parola riservata fare, un ritorno a capo, backslash \ o un punto e virgola;.
Esempio
#!/usr/bin/ruby
$i = 0
$num = 5
while $i < $num do
puts("Inside the loop i = #$i" )
$i +=1
end
Questo produrrà il seguente risultato:
Inside the loop i = 0
Inside the loop i = 1
Inside the loop i = 2
Inside the loop i = 3
Inside the loop i = 4
Rubino mentre modificatore
Sintassi
code while condition
OR
begin
code
end while conditional
Esegue il codice mentre il condizionale è vero.
Se un modificatore while segue un'istruzione di inizio senza clausole di salvataggio o di sicurezza, il codice viene eseguito una volta prima della valutazione del condizionale.
Esempio
#!/usr/bin/ruby
$i = 0
$num = 5
begin
puts("Inside the loop i = #$i" )
$i +=1
end while $i < $num
Questo produrrà il seguente risultato:
Inside the loop i = 0
Inside the loop i = 1
Inside the loop i = 2
Inside the loop i = 3
Inside the loop i = 4
Ruby fino a Statement
until conditional [do]
code
end
Esegue il codice mentre il condizionale è falso. Un fino condizionale della dichiarazione è separato dal codice dalla parola riservata fare , un ritorno a capo, o un punto e virgola.
Esempio
#!/usr/bin/ruby
$i = 0
$num = 5
until $i > $num do
puts("Inside the loop i = #$i" )
$i +=1;
end
Questo produrrà il seguente risultato:
Inside the loop i = 0
Inside the loop i = 1
Inside the loop i = 2
Inside the loop i = 3
Inside the loop i = 4
Inside the loop i = 5
Rubino fino al modificatore
Sintassi
code until conditional
OR
begin
code
end until conditional
Esegue il codice mentre il condizionale è falso.
Se un modificatore until segue un'istruzione di inizio senza clausole di salvataggio o di sicurezza, il codice viene eseguito una volta prima della valutazione condizionale .
Esempio
#!/usr/bin/ruby
$i = 0
$num = 5
begin
puts("Inside the loop i = #$i" )
$i +=1;
end until $i > $num
Questo produrrà il seguente risultato:
Inside the loop i = 0
Inside the loop i = 1
Inside the loop i = 2
Inside the loop i = 3
Inside the loop i = 4
Inside the loop i = 5
Ruby for Statement
Sintassi
for variable [, variable ...] in expression [do]
code
end
Esegue il codice una volta per ogni elemento in expression .
Esempio
#!/usr/bin/ruby
for i in 0..5
puts "Value of local variable is #{i}"
end
Qui abbiamo definito l'intervallo 0..5. L'istruzione per i in 0..5 consentirà a i di assumere valori nell'intervallo da 0 a 5 (incluso 5). Questo produrrà il seguente risultato:
Value of local variable is 0
Value of local variable is 1
Value of local variable is 2
Value of local variable is 3
Value of local variable is 4
Value of local variable is 5
Un ciclo for ... in è quasi esattamente equivalente al seguente:
(expression).each do |variable[, variable...]| code end
tranne per il fatto che un ciclo for non crea un nuovo ambito per le variabili locali. Una per loop espressione è separato dal codice dalla parola riservata fare, un ritorno a capo, o un punto e virgola.
Esempio
#!/usr/bin/ruby
(0..5).each do |i|
puts "Value of local variable is #{i}"
end
Questo produrrà il seguente risultato:
Value of local variable is 0
Value of local variable is 1
Value of local variable is 2
Value of local variable is 3
Value of local variable is 4
Value of local variable is 5
Dichiarazione Ruby break
Sintassi
break
Termina il ciclo più interno. Termina un metodo con un blocco associato se chiamato all'interno del blocco (con il metodo che restituisce nil).
Esempio
#!/usr/bin/ruby
for i in 0..5
if i > 2 then
break
end
puts "Value of local variable is #{i}"
end
Questo produrrà il seguente risultato:
Value of local variable is 0
Value of local variable is 1
Value of local variable is 2
Dichiarazione successiva di Ruby
Sintassi
next
Salta all'iterazione successiva del ciclo più interno. Termina l'esecuzione di un blocco se chiamato all'interno di un blocco (con yield o call che restituisce zero).
Esempio
#!/usr/bin/ruby
for i in 0..5
if i < 2 then
next
end
puts "Value of local variable is #{i}"
end
Questo produrrà il seguente risultato:
Value of local variable is 2
Value of local variable is 3
Value of local variable is 4
Value of local variable is 5
Ruby redo Statement
Sintassi
redo
Riavvia questa iterazione del ciclo più interno, senza controllare le condizioni del ciclo. Riavvia yield o call se chiamato all'interno di un blocco.
Esempio
#!/usr/bin/ruby
for i in 0..5
if i < 2 then
puts "Value of local variable is #{i}"
redo
end
end
Questo produrrà il seguente risultato e andrà in un ciclo infinito -
Value of local variable is 0
Value of local variable is 0
............................
Istruzione di ripetizione di Ruby
Sintassi
retry
Se riprova appare nella clausola di salvataggio dell'espressione iniziale, ricomincia dall'inizio del corpo iniziale.
begin
do_something # exception raised
rescue
# handles error
retry # restart from beginning
end
Se retry appare nell'iteratore, il blocco o il corpo dell'espressione for , riavvia il richiamo della chiamata dell'iteratore. Gli argomenti dell'iteratore vengono rivalutati.
for i in 1..5
retry if some_condition # restart from i == 1
end
Esempio
#!/usr/bin/ruby
for i in 0..5
retry if i > 2
puts "Value of local variable is #{i}"
end
Questo produrrà il seguente risultato e andrà in un ciclo infinito -
Value of local variable is 1
Value of local variable is 2
Value of local variable is 1
Value of local variable is 2
Value of local variable is 1
Value of local variable is 2
............................
I metodi Ruby sono molto simili alle funzioni in qualsiasi altro linguaggio di programmazione. I metodi Ruby vengono utilizzati per raggruppare una o più istruzioni ripetibili in una singola unità.
I nomi dei metodi dovrebbero iniziare con una lettera minuscola. Se inizi un nome di metodo con una lettera maiuscola, Ruby potrebbe pensare che sia una costante e quindi può analizzare la chiamata in modo errato.
I metodi dovrebbero essere definiti prima di chiamarli, altrimenti Ruby solleverà un'eccezione per invocare metodi non definiti.
Sintassi
def method_name [( [arg [= default]]...[, * arg [, &expr ]])]
expr..
end
Quindi, puoi definire un metodo semplice come segue:
def method_name
expr..
end
Puoi rappresentare un metodo che accetta parametri come questo:
def method_name (var1, var2)
expr..
end
È possibile impostare valori predefiniti per i parametri, che verranno utilizzati se il metodo viene chiamato senza passare i parametri richiesti -
def method_name (var1 = value1, var2 = value2)
expr..
end
Ogni volta che chiami il metodo semplice, scrivi solo il nome del metodo come segue:
method_name
Tuttavia, quando chiami un metodo con parametri, scrivi il nome del metodo insieme ai parametri, come -
method_name 25, 30
Lo svantaggio più importante nell'usare metodi con parametri è che devi ricordare il numero di parametri ogni volta che chiami tali metodi. Ad esempio, se un metodo accetta tre parametri e ne passi solo due, Ruby visualizza un errore.
Esempio
#!/usr/bin/ruby
def test(a1 = "Ruby", a2 = "Perl")
puts "The programming language is #{a1}"
puts "The programming language is #{a2}"
end
test "C", "C++"
test
Questo produrrà il seguente risultato:
The programming language is C
The programming language is C++
The programming language is Ruby
The programming language is Perl
Valori restituiti dai metodi
Ogni metodo in Ruby restituisce un valore per impostazione predefinita. Questo valore restituito sarà il valore dell'ultima istruzione. Ad esempio:
def test
i = 100
j = 10
k = 0
end
Questo metodo, quando chiamato, restituirà l'ultima variabile dichiarata k .
Dichiarazione di ritorno di Ruby
L' istruzione return in ruby viene utilizzata per restituire uno o più valori da un metodo Ruby.
Sintassi
return [expr[`,' expr...]]
Se vengono fornite più di due espressioni, la matrice contenente questi valori sarà il valore restituito. Se non viene fornita alcuna espressione, nil sarà il valore restituito.
Esempio
return
OR
return 12
OR
return 1,2,3
Dai un'occhiata a questo esempio:
#!/usr/bin/ruby
def test
i = 100
j = 200
k = 300
return i, j, k
end
var = test
puts var
Questo produrrà il seguente risultato:
100
200
300
Numero variabile di parametri
Supponiamo che tu dichiari un metodo che accetta due parametri, ogni volta che chiami questo metodo, devi passare due parametri insieme ad esso.
Tuttavia, Ruby ti consente di dichiarare metodi che funzionano con un numero variabile di parametri. Esaminiamo un esempio di questo:
#!/usr/bin/ruby
def sample (*test)
puts "The number of parameters is #{test.length}"
for i in 0...test.length
puts "The parameters are #{test[i]}"
end
end
sample "Zara", "6", "F"
sample "Mac", "36", "M", "MCA"
In questo codice, hai dichiarato un esempio di metodo che accetta un test di parametro. Tuttavia, questo parametro è un parametro variabile. Ciò significa che questo parametro può contenere qualsiasi numero di variabili. Quindi, il codice sopra produrrà il seguente risultato:
The number of parameters is 3
The parameters are Zara
The parameters are 6
The parameters are F
The number of parameters is 4
The parameters are Mac
The parameters are 36
The parameters are M
The parameters are MCA
Metodi di classe
Quando un metodo viene definito al di fuori della definizione della classe, il metodo viene contrassegnato come privato per impostazione predefinita. D'altra parte, i metodi definiti nella definizione della classe sono contrassegnati come pubblici per impostazione predefinita. La visibilità predefinita e il marchio privato dei metodi possono essere modificati da pubblico o privato del modulo.
Ogni volta che vuoi accedere a un metodo di una classe, devi prima creare un'istanza della classe. Quindi, utilizzando l'oggetto, puoi accedere a qualsiasi membro della classe.
Ruby ti dà un modo per accedere a un metodo senza istanziare una classe. Vediamo come viene dichiarato e utilizzato un metodo di classe:
class Accounts
def reading_charge
end
def Accounts.return_date
end
end
Guarda come viene dichiarato il metodo return_date. Viene dichiarato con il nome della classe seguito da un punto, seguito dal nome del metodo. È possibile accedere direttamente a questo metodo di classe come segue:
Accounts.return_date
Per accedere a questo metodo, non è necessario creare oggetti della classe Account.
Istruzione alias Ruby
Questo fornisce alias per metodi o variabili globali. Gli alias non possono essere definiti all'interno del corpo del metodo. L'alias del metodo mantiene la definizione corrente del metodo, anche quando i metodi vengono sovrascritti.
È vietato creare alias per le variabili globali numerate ($ 1, $ 2, ...). L'override delle variabili globali incorporate può causare seri problemi.
Sintassi
alias method-name method-name
alias global-variable-name global-variable-name
Esempio
alias foo bar
alias $MATCH $&
Qui abbiamo definito l'alias foo per bar e $ MATCH è un alias per $ &
Ruby undef Statement
Ciò annulla la definizione del metodo. Un undef non può apparire nel corpo del metodo.
Utilizzando undef e alias , l'interfaccia della classe può essere modificata indipendentemente dalla superclasse, ma si noti che potrebbero essere programmi danneggiati dalla chiamata del metodo interno a self.
Sintassi
undef method-name
Esempio
Per annullare la definizione di un metodo chiamato bar, procedi come segue:
undef bar
Hai visto come Ruby definisce i metodi in cui puoi inserire un numero di istruzioni e poi chiami quel metodo. Allo stesso modo, Ruby ha un concetto di Block.
Un blocco è costituito da blocchi di codice.
Assegna un nome a un blocco.
Il codice nel blocco è sempre racchiuso tra parentesi graffe ({}).
Un blocco viene sempre richiamato da una funzione con lo stesso nome di quella del blocco. Ciò significa che se hai un blocco con il nome test , allora utilizzi la funzione test per richiamare questo blocco.
Si richiama un blocco utilizzando l' istruzione yield .
Sintassi
block_name {
statement1
statement2
..........
}
Qui imparerai a invocare un blocco usando una semplice dichiarazione di rendimento . Imparerai anche a usare un'istruzione yield con parametri per invocare un blocco. Controllerai il codice di esempio con entrambi i tipi di dichiarazioni di rendimento .
La dichiarazione di rendimento
Diamo un'occhiata a un esempio della dichiarazione di rendimento:
#!/usr/bin/ruby
def test
puts "You are in the method"
yield
puts "You are again back to the method"
yield
end
test {puts "You are in the block"}
Questo produrrà il seguente risultato:
You are in the method
You are in the block
You are again back to the method
You are in the block
Puoi anche passare parametri con la dichiarazione di rendimento. Ecco un esempio:
#!/usr/bin/ruby
def test
yield 5
puts "You are in the method test"
yield 100
end
test {|i| puts "You are in the block #{i}"}
Questo produrrà il seguente risultato:
You are in the block 5
You are in the method test
You are in the block 100
Qui, la dichiarazione di rendimento è scritta seguita dai parametri. Puoi anche passare più di un parametro. Nel blocco, inserisci una variabile tra due linee verticali (||) per accettare i parametri. Pertanto, nel codice precedente, l'istruzione yield 5 passa il valore 5 come parametro al blocco di test.
Ora, guarda la seguente dichiarazione:
test {|i| puts "You are in the block #{i}"}
Qui, il valore 5 viene ricevuto nella variabile i . Ora, osserva la seguente dichiarazione put :
puts "You are in the block #{i}"
L'output di questa istruzione put è:
You are in the block 5
Se vuoi passare più di un parametro, la dichiarazione di rendimento diventa -
yield a, b
e il blocco è -
test {|a, b| statement}
I parametri saranno separati da virgole.
Blocchi e metodi
Hai visto come un blocco e un metodo possono essere associati tra loro. Normalmente si richiama un blocco utilizzando l'istruzione yield da un metodo che ha lo stesso nome di quello del blocco. Pertanto, scrivi -
#!/usr/bin/ruby
def test
yield
end
test{ puts "Hello world"}
Questo esempio è il modo più semplice per implementare un blocco. Si chiama il blocco di prova utilizzando l' istruzione yield .
Ma se l'ultimo argomento di un metodo è preceduto da &, allora puoi passare un blocco a questo metodo e questo blocco verrà assegnato all'ultimo parametro. Nel caso in cui sia * che & siano presenti nell'elenco degli argomenti, & dovrebbe venire dopo.
#!/usr/bin/ruby
def test(&block)
block.call
end
test { puts "Hello World!"}
Questo produrrà il seguente risultato:
Hello World!
Blocchi BEGIN e END
Ogni file sorgente di Ruby può dichiarare i blocchi di codice da eseguire mentre il file viene caricato (i blocchi BEGIN) e dopo che il programma ha terminato l'esecuzione (i blocchi END).
#!/usr/bin/ruby
BEGIN {
# BEGIN block code
puts "BEGIN code block"
}
END {
# END block code
puts "END code block"
}
# MAIN block code
puts "MAIN code block"
Un programma può includere più blocchi BEGIN e END. I blocchi BEGIN vengono eseguiti nell'ordine in cui vengono rilevati. I blocchi END vengono eseguiti in ordine inverso. Quando viene eseguito, il programma di cui sopra produce il seguente risultato:
BEGIN code block
MAIN code block
END code block
I moduli sono un modo per raggruppare metodi, classi e costanti. I moduli ti offrono due vantaggi principali.
I moduli forniscono uno spazio dei nomi e prevengono conflitti di nome.
I moduli implementano la funzione di mixin .
I moduli definiscono uno spazio dei nomi, una sandbox in cui i metodi e le costanti possono giocare senza doversi preoccupare di essere calpestati da altri metodi e costanti.
Sintassi
module Identifier
statement1
statement2
...........
end
Le costanti del modulo sono denominate proprio come le costanti di classe, con una lettera iniziale maiuscola. Anche le definizioni dei metodi sono simili: i metodi dei moduli sono definiti proprio come i metodi delle classi.
Come con i metodi di classe, si chiama un metodo di modulo facendo precedere il suo nome con il nome del modulo e un punto e si fa riferimento a una costante utilizzando il nome del modulo e due due punti.
Esempio
#!/usr/bin/ruby
# Module defined in trig.rb file
module Trig
PI = 3.141592654
def Trig.sin(x)
# ..
end
def Trig.cos(x)
# ..
end
end
Possiamo definire un altro modulo con lo stesso nome di funzione ma funzionalità diverse -
#!/usr/bin/ruby
# Module defined in moral.rb file
module Moral
VERY_BAD = 0
BAD = 1
def Moral.sin(badness)
# ...
end
end
Come i metodi di classe, ogni volta che si definisce un metodo in un modulo, si specifica il nome del modulo seguito da un punto e quindi il nome del metodo.
Ruby richiede Statement
L'istruzione require è simile all'istruzione include di C e C ++ e all'istruzione import di Java. Se un terzo programma desidera utilizzare un modulo definito, può semplicemente caricare i file del modulo utilizzando l' istruzione require di Ruby -
Sintassi
require filename
Qui non è necessario dare .rb estensione insieme a un nome file.
Esempio
$LOAD_PATH << '.'
require 'trig.rb'
require 'moral'
y = Trig.sin(Trig::PI/4)
wrongdoing = Moral.sin(Moral::VERY_BAD)
Qui stiamo usando $LOAD_PATH << '.'per rendere Ruby consapevole che i file inclusi devono essere cercati nella directory corrente. Se non vuoi usare $ LOAD_PATH, puoi usarerequire_relative per includere file da una directory relativa.
IMPORTANT- Qui, entrambi i file contengono lo stesso nome di funzione. Quindi, ciò comporterà un'ambiguità del codice durante l'inclusione nel programma chiamante, ma i moduli evitano questa ambiguità del codice e siamo in grado di chiamare la funzione appropriata utilizzando il nome del modulo.
Ruby include Statement
Puoi incorporare un modulo in una classe. Per incorporare un modulo in una classe, utilizza l' istruzione include nella classe:
Sintassi
include modulename
Se un modulo è definito in un file separato, è necessario includere quel file utilizzando l' istruzione require prima di incorporare il modulo in una classe.
Esempio
Considera il seguente modulo scritto nel file support.rb .
module Week
FIRST_DAY = "Sunday"
def Week.weeks_in_month
puts "You have four weeks in a month"
end
def Week.weeks_in_year
puts "You have 52 weeks in a year"
end
end
Ora puoi includere questo modulo in una classe come segue:
#!/usr/bin/ruby
$LOAD_PATH << '.'
require "support"
class Decade
include Week
no_of_yrs = 10
def no_of_months
puts Week::FIRST_DAY
number = 10*12
puts number
end
end
d1 = Decade.new
puts Week::FIRST_DAY
Week.weeks_in_month
Week.weeks_in_year
d1.no_of_months
Questo produrrà il seguente risultato:
Sunday
You have four weeks in a month
You have 52 weeks in a year
Sunday
120
Mixins in Ruby
Prima di passare a questa sezione, si presume che tu abbia la conoscenza dei concetti orientati agli oggetti.
Quando una classe può ereditare funzionalità da più di una classe genitore, si suppone che la classe mostri ereditarietà multipla.
Ruby non supporta direttamente l'ereditarietà multipla, ma i moduli Ruby hanno un altro meraviglioso utilizzo. In un colpo solo, eliminano praticamente la necessità di eredità multipla, fornendo una struttura chiamata mixin .
I mixin ti offrono un modo meravigliosamente controllato per aggiungere funzionalità alle classi. Tuttavia, il loro vero potere emerge quando il codice nel mixin inizia a interagire con il codice nella classe che lo utilizza.
Esaminiamo il seguente codice di esempio per comprendere meglio il mixin:
module A
def a1
end
def a2
end
end
module B
def b1
end
def b2
end
end
class Sample
include A
include B
def s1
end
end
samp = Sample.new
samp.a1
samp.a2
samp.b1
samp.b2
samp.s1
Il modulo A è costituito dai metodi a1 e a2. Il modulo B è costituito dai metodi b1 e b2. La classe Sample include entrambi i moduli A e B. La classe Sample può accedere a tutti e quattro i metodi, ovvero a1, a2, b1 e b2. Pertanto, puoi vedere che la classe Sample eredita da entrambi i moduli. Quindi, puoi dire che la classe Sample mostra ereditarietà multipla o un mixin .
Un oggetto String in Ruby contiene e manipola una sequenza arbitraria di uno o più byte, che tipicamente rappresentano caratteri che rappresentano il linguaggio umano.
Le stringhe letterali più semplici sono racchiuse tra virgolette singole (il carattere apostrofo). Il testo tra virgolette è il valore della stringa -
'This is a simple Ruby string literal'
Se è necessario inserire un apostrofo all'interno di una stringa letterale tra virgolette singole, anteporla a una barra rovesciata, in modo che l'interprete Ruby non pensi che termini la stringa -
'Won\'t you read O\'Reilly\'s book?'
Il backslash funziona anche per sfuggire a un altro backslash, in modo che il secondo backslash non venga interpretato come un carattere di escape.
Di seguito sono riportate le funzionalità relative alle stringhe di Ruby.
Sostituzione di espressioni
La sostituzione dell'espressione è un mezzo per incorporare il valore di qualsiasi espressione Ruby in una stringa usando # {e} -
#!/usr/bin/ruby
x, y, z = 12, 36, 72
puts "The value of x is #{ x }."
puts "The sum of x and y is #{ x + y }."
puts "The average was #{ (x + y + z)/3 }."
Questo produrrà il seguente risultato:
The value of x is 12.
The sum of x and y is 48.
The average was 40.
Stringhe delimitate generali
Con stringhe delimitate generali, puoi creare stringhe all'interno di una coppia di caratteri delimitatori corrispondenti sebbene arbitrari, ad esempio,!, (, {, <, Ecc., Preceduti da un carattere di percentuale (%). Q, q e x hanno significati speciali . Le stringhe delimitate generali possono essere -
%{Ruby is fun.} equivalent to "Ruby is fun."
%Q{ Ruby is fun. } equivalent to " Ruby is fun. "
%q[Ruby is fun.] equivalent to a single-quoted string
%x!ls! equivalent to back tick command output `ls`
Caratteri di fuga
NOTE- In una stringa tra virgolette doppie, viene interpretato un carattere di escape; in una stringa tra virgolette singole, viene conservato un carattere di escape.
Notazione backslash | Carattere esadecimale | Descrizione |
---|---|---|
\un | 0x07 | Campanello o avviso |
\ b | 0x08 | Backspace |
\ cx | Control-x | |
\ Cx | Control-x | |
\ e | 0x1b | Fuga |
\ f | 0x0c | Formfeed |
\ M- \ Cx | Meta-Control-x | |
\ n | 0x0a | Nuova linea |
\ nnn | Notazione ottale, dove n è compreso tra 0,7 | |
\ r | 0x0d | Ritorno in carrozza |
\S | 0x20 | Spazio |
\ t | 0x09 | Tab |
\ v | 0x0b | Scheda verticale |
\X | Carattere x | |
\ xnn | Notazione esadecimale, dove n è compreso tra 0,9, af o AF |
Codifica dei caratteri
Il set di caratteri predefinito per Ruby è ASCII, i cui caratteri possono essere rappresentati da singoli byte. Se si utilizza UTF-8 o un altro set di caratteri moderno, i caratteri possono essere rappresentati da uno a quattro byte.
Puoi cambiare il tuo set di caratteri usando $ KCODE all'inizio del tuo programma, in questo modo:
$KCODE = 'u'
Sr.No. | Codice e descrizione |
---|---|
1 | a ASCII (uguale a nessuno). Questa è l'impostazione predefinita. |
2 | e EUC. |
3 | n Nessuno (come ASCII). |
4 | u UTF-8. |
Metodi incorporati di stringa
Abbiamo bisogno di un'istanza dell'oggetto String per chiamare un metodo String. Di seguito è riportato il modo per creare un'istanza di un oggetto String:
new [String.new(str = "")]
Ciò restituirà un nuovo oggetto stringa contenente una copia di str . Ora, usando str object, possiamo tutti usare qualsiasi metodo di istanza disponibile. Ad esempio:
#!/usr/bin/ruby
myStr = String.new("THIS IS TEST")
foo = myStr.downcase
puts "#{foo}"
Questo produrrà il seguente risultato:
this is test
Sr.No. | Metodi e descrizione |
---|---|
1 | str % arg Formatta una stringa utilizzando una specifica di formato. arg deve essere un array se contiene più di una sostituzione. Per informazioni sulla specifica del formato, vedere sprintf in "Modulo kernel". |
2 | str * integer Restituisce una nuova stringa contenente un numero intero moltiplicato per str. In altre parole, str è un numero intero ripetuto. |
3 | str + other_str Concatena other_str a str. |
4 | str << obj Concatena un oggetto a str. Se l'oggetto è un numero fisso nell'intervallo 0,255, viene convertito in un carattere. Confrontalo con concat. |
5 | str <=> other_str Confronta str con other_str, restituendo -1 (minore di), 0 (uguale) o 1 (maggiore di). Il confronto fa distinzione tra maiuscole e minuscole. |
6 | str == obj Verifica l'uguaglianza di str e obj. Se obj non è una stringa, restituisce false; restituisce true se str <=> obj restituisce 0. |
7 | str =~ obj Confronta str con un modello di espressione regolare obj. Restituisce la posizione in cui inizia la partita; in caso contrario, false. |
8 | str.capitalize Capitalizza una stringa. |
9 | str.capitalize! Uguale a capitalize, ma le modifiche vengono apportate sul posto. |
10 | str.casecmp Effettua un confronto tra le stringhe senza distinzione tra maiuscole e minuscole. |
11 | str.center Centra una stringa. |
12 | str.chomp Rimuove il separatore di record ($ /), solitamente \ n, dalla fine di una stringa. Se non esiste alcun separatore di record, non fa nulla. |
13 | str.chomp! Uguale a chomp, ma le modifiche vengono apportate sul posto. |
14 | str.chop Rimuove l'ultimo carattere in str. |
15 | str.chop! Uguale a chop, ma le modifiche vengono apportate sul posto. |
16 | str.concat(other_str) Concatena other_str a str. |
17 | str.count(str, ...) Conta uno o più set di caratteri. Se è presente più di un set di caratteri, conta l'intersezione di tali set |
18 | str.crypt(other_str) Applica un hash crittografico unidirezionale a str. L'argomento è la stringa salt, che dovrebbe essere lunga due caratteri, ogni carattere nell'intervallo az, AZ, 0.9,. o /. |
19 | str.delete(other_str, ...) Restituisce una copia di str con tutti i caratteri nell'intersezione dei suoi argomenti eliminati. |
20 | str.delete!(other_str, ...) Uguale a Elimina, ma le modifiche vengono apportate sul posto. |
21 | str.downcase Restituisce una copia di str con tutte le lettere maiuscole sostituite da minuscole. |
22 | str.downcase! Come il downcase, ma le modifiche vengono apportate sul posto. |
23 | str.dump Restituisce una versione di str con tutti i caratteri non stampabili sostituiti dalla notazione \ nnn e tutti i caratteri speciali con escape. |
24 | str.each(separator = $/) { |substr| block } Divide str usando l'argomento come separatore di record ($ / per impostazione predefinita), passando ogni sottostringa al blocco fornito. |
25 | str.each_byte { |fixnum| block } Passa ogni byte da str al blocco, restituendo ogni byte come rappresentazione decimale del byte. |
26 | str.each_line(separator=$/) { |substr| block } Divide str usando l'argomento come separatore di record ($ / per impostazione predefinita), passando ogni sottostringa al blocco fornito. |
27 | str.empty? Restituisce vero se str è vuoto (ha lunghezza zero). |
28 | str.eql?(other) Due stringhe sono uguali se hanno la stessa lunghezza e contenuto. |
29 | str.gsub(pattern, replacement) [or] str.gsub(pattern) { |match| block } Restituisce una copia di str con tutte le occorrenze di pattern sostituite con la sostituzione o il valore del blocco. Il pattern sarà tipicamente un Regexp; se è una stringa, non verranno interpretati i metacaratteri delle espressioni regolari (ovvero / \ d / corrisponderà a una cifra, ma "\ d" corrisponderà a una barra rovesciata seguita da una "d") |
30 | str[fixnum] [or] str[fixnum,fixnum] [or] str[range] [or] str[regexp] [or] str[regexp, fixnum] [or] str[other_str] Fa riferimento a str, utilizzando i seguenti argomenti: one Fixnum, restituisce un codice carattere in fixnum; due Fixnum, restituisce una sottostringa a partire da un offset (primo fixnum) fino a length (secondo fixnum); intervallo, restituisce una sottostringa nell'intervallo; regexp restituisce una parte della stringa corrispondente; regexp con fixnum, restituisce i dati corrispondenti a fixnum; other_str restituisce la sottostringa corrispondente a other_str. Un Fixnum negativo inizia alla fine della stringa con -1. |
31 | str[fixnum] = fixnum [or] str[fixnum] = new_str [or] str[fixnum, fixnum] = new_str [or] str[range] = aString [or] str[regexp] = new_str [or] str[regexp, fixnum] = new_str [or] str[other_str] = new_str ] Sostituisci (assegna) tutto o parte di una stringa. Sinonimo di slice !. |
32 | str.gsub!(pattern, replacement) [or] str.gsub!(pattern) { |match|block } Esegue le sostituzioni di String # gsub in posizione, restituendo str o nil se non sono state eseguite sostituzioni. |
33 | str.hash Restituisce un hash in base alla lunghezza e al contenuto della stringa. |
34 | str.hex Tratta i caratteri iniziali di str come una stringa di cifre esadecimali (con un segno opzionale e uno 0x opzionale) e restituisce il numero corrispondente. Zero viene restituito in caso di errore. |
35 | str.include? other_str [or] str.include? fixnum Restituisce vero se str contiene la stringa o il carattere specificato. |
36 | str.index(substring [, offset]) [or] str.index(fixnum [, offset]) [or] str.index(regexp [, offset]) Restituisce l'indice della prima occorrenza della sottostringa, del carattere (fixnum) o del pattern (regexp) in str. Restituisce zero se non trovato. Se è presente il secondo parametro, specifica la posizione nella stringa per iniziare la ricerca. |
37 | str.insert(index, other_str) Inserisce altro_str prima del carattere all'indice dato, modificando str. Gli indici negativi contano dalla fine della stringa e vengono inseriti dopo il carattere specificato. L'intento è inserire una stringa in modo che inizi dall'indice dato. |
38 | str.inspect Restituisce una versione stampabile di str, con caratteri speciali di escape. |
39 | str.intern [or] str.to_sym Restituisce il Simbolo corrispondente a str, creando il simbolo se non esisteva in precedenza. |
40 | str.length Restituisce la lunghezza di str. Confronta le dimensioni. |
41 | str.ljust(integer, padstr = ' ') Se intero è maggiore della lunghezza di str, restituisce una nuova stringa di lunghezza intero con str giustificato a sinistra e riempito con padstr; in caso contrario, restituisce str. |
42 | str.lstrip Restituisce una copia di str con gli spazi iniziali rimossi. |
43 | str.lstrip! Rimuove gli spazi bianchi iniziali da str, restituendo nil se non è stata apportata alcuna modifica. |
44 | str.match(pattern) Converte pattern in un Regexp (se non lo è già), quindi invoca il suo metodo di corrispondenza su str. |
45 | str.oct Tratta i caratteri iniziali di str come una stringa di cifre ottali (con un segno opzionale) e restituisce il numero corrispondente. Restituisce 0 se la conversione non riesce. |
46 | str.replace(other_str) Sostituisce il contenuto e la contaminazione di str con i valori corrispondenti in other_str. |
47 | str.reverse Restituisce una nuova stringa con i caratteri di str in ordine inverso. |
48 | str.reverse! Inverte str in posizione. |
49 | str.rindex(substring [, fixnum]) [or] str.rindex(fixnum [, fixnum]) [or] str.rindex(regexp [, fixnum]) Restituisce l'indice dell'ultima occorrenza della sottostringa, del carattere (fixnum) o del pattern (regexp) in str. Restituisce zero se non trovato. Se il secondo parametro è presente, specifica la posizione nella stringa per terminare la ricerca. I caratteri oltre questo punto non verranno considerati. |
50. | str.rjust(integer, padstr = ' ') Se intero è maggiore della lunghezza di str, restituisce una nuova stringa di lunghezza intero con str giustificato a destra e riempito con padstr; in caso contrario, restituisce str. |
51 | str.rstrip Restituisce una copia di str con gli spazi vuoti finali rimossi. |
52 | str.rstrip! Rimuove gli spazi vuoti finali da str, restituendo zero se non è stata apportata alcuna modifica. |
53 | str.scan(pattern) [or] str.scan(pattern) { |match, ...| block } Entrambe le forme eseguono l'iterazione attraverso str, corrispondenti al modello (che può essere un Regexp o una String). Per ogni corrispondenza, viene generato un risultato e aggiunto all'array dei risultati o passato al blocco. Se il pattern non contiene gruppi, ogni singolo risultato è costituito dalla stringa corrispondente, $ &. Se il pattern contiene gruppi, ogni singolo risultato è esso stesso un array contenente una voce per gruppo. |
54 | str.slice(fixnum) [or] str.slice(fixnum, fixnum) [or] str.slice(range) [or] str.slice(regexp) [or] str.slice(regexp, fixnum) [or] str.slice(other_str) See str[fixnum], etc. str.slice!(fixnum) [or] str.slice!(fixnum, fixnum) [or] str.slice!(range) [or] str.slice!(regexp) [or] str.slice!(other_str) Elimina la parte specificata da str e restituisce la parte eliminata. I form che accettano un Fixnum solleveranno un IndexError se il valore è fuori intervallo; il modulo Range solleverà un RangeError e i form Regexp e String ignoreranno silenziosamente l'assegnazione. |
55 | str.split(pattern = $, [limit]) Divide str in sottostringhe in base a un delimitatore, restituendo un array di queste sottostringhe. Se pattern è una stringa, il suo contenuto viene utilizzato come delimitatore quando si divide str. Se pattern è un singolo spazio, str viene suddiviso in spazi vuoti, con spazi bianchi iniziali e sequenze di caratteri contigui ignorati. Se pattern è un'espressione regolare, str è diviso dove corrisponde il pattern. Ogni volta che il modello corrisponde a una stringa di lunghezza zero, str viene suddiviso in singoli caratteri. Se pattern viene omesso, il valore di$; is used. If $; è nil (che è l'impostazione predefinita), str è diviso su spazi bianchi come se fosse specificato ``. Se il parametro limit viene omesso, i campi nulli finali vengono soppressi. Se limite è un numero positivo, verrà restituito al massimo quel numero di campi (se limite è 1, l'intera stringa viene restituita come unica voce in un array). Se negativo, non vi è alcun limite al numero di campi restituiti e i campi nulli finali non vengono soppressi. |
56 | str.squeeze([other_str]*) Crea un set di caratteri dai parametri other_str utilizzando la procedura descritta per String # count. Restituisce una nuova stringa in cui le esecuzioni dello stesso carattere che si verificano in questo set vengono sostituite da un singolo carattere. Se non vengono forniti argomenti, tutte le sequenze di caratteri identici vengono sostituite da un singolo carattere. |
57 | str.squeeze!([other_str]*) Comprime str in posizione, restituendo str o nil se non sono state apportate modifiche. |
58 | str.strip Restituisce una copia di str con gli spazi iniziali e finali rimossi. |
59 | str.strip! Rimuove gli spazi bianchi iniziali e finali da str. Restituisce nil se str non è stato alterato. |
60 | str.sub(pattern, replacement) [or] str.sub(pattern) { |match| block } Restituisce una copia di str con la prima occorrenza di pattern sostituita con la sostituzione o il valore del blocco. Il pattern sarà tipicamente un Regexp; se è una stringa, non verranno interpretati i metacaratteri delle espressioni regolari. |
61 | str.sub!(pattern, replacement) [or] str.sub!(pattern) { |match| block } Esegue le sostituzioni di String # sub in posizione, restituendo str o nil se non sono state eseguite sostituzioni. |
62 | str.succ [or] str.next Restituisce il successore a str. |
63 | str.succ! [or] str.next! Equivalente a String # succ, ma modifica il ricevitore in posizione. |
64 | str.sum(n = 16) Restituisce un checksum di base in n bit dei caratteri in str, dove n è il parametro Fixnum opzionale, predefinito a 16. Il risultato è semplicemente la somma del valore binario di ogni carattere in str modulo 2n - 1. Questo non è un particolare buon checksum. |
65 | str.swapcase Restituisce una copia di str con caratteri alfabetici maiuscoli convertiti in caratteri minuscoli e minuscoli convertiti in maiuscoli. |
66 | str.swapcase! Equivalente a String # swapcase, ma modifica il ricevitore in posizione, restituendo str o nil se non sono state apportate modifiche. |
67 | str.to_f > Restituisce il risultato dell'interpretazione dei caratteri iniziali in str come un numero a virgola mobile. I caratteri estranei oltre la fine di un numero valido vengono ignorati. Se non è presente un numero valido all'inizio di str, viene restituito 0.0. Questo metodo non genera mai un'eccezione. |
68 | str.to_i(base = 10) Restituisce il risultato dell'interpretazione dei caratteri iniziali in str come una base intera (base 2, 8, 10 o 16). I caratteri estranei oltre la fine di un numero valido vengono ignorati. Se non c'è un numero valido all'inizio di str, viene restituito 0. Questo metodo non genera mai un'eccezione. |
69 | str.to_s [or] str.to_str Restituisce il ricevitore. |
70 | str.tr(from_str, to_str) Restituisce una copia di str con i caratteri in from_str sostituiti dai caratteri corrispondenti in to_str. Se to_str è più corto di from_str, viene riempito con il suo ultimo carattere. Entrambe le stringhe possono utilizzare la notazione c1.c2 per indicare intervalli di caratteri e from_str può iniziare con ^, che denota tutti i caratteri tranne quelli elencati. |
71 | str.tr!(from_str, to_str) Traduce str in posizione, utilizzando le stesse regole di String # tr. Restituisce str o nil se non sono state apportate modifiche. |
72 | str.tr_s(from_str, to_str) Elabora una copia di str come descritto in String # tr, quindi rimuove i caratteri duplicati nelle regioni interessate dalla traduzione. |
73 | str.tr_s!(from_str, to_str) Esegue l'elaborazione della stringa # tr_s su str in posizione, restituendo str o nil se non sono state apportate modifiche. |
74 | str.unpack(format) > Decodifica str (che può contenere dati binari) in base alla stringa di formato, restituendo un array di ogni valore estratto. La stringa di formato consiste in una sequenza di direttive di un carattere, riassunte nella Tabella 18. Ciascuna direttiva può essere seguita da un numero, che indica il numero di volte da ripetere con questa direttiva. Un asterisco (*) utilizzerà tutti gli elementi rimanenti. Ciascuna delle direttive sSiIlL può essere seguita da un trattino basso (_) per utilizzare la dimensione nativa della piattaforma sottostante per il tipo specificato; in caso contrario, utilizza una dimensione coerente indipendente dalla piattaforma. Gli spazi vengono ignorati nella stringa di formato. |
75 | str.upcase Restituisce una copia di str con tutte le lettere minuscole sostituite con le loro controparti maiuscole. L'operazione è insensibile alle impostazioni locali. Sono interessati solo i caratteri dalla a alla z. |
76 | str.upcase! Cambia il contenuto di str in maiuscolo, restituendo zero se non vengono apportate modifiche. |
77 | str.upto(other_str) { |s| block } Scorre i valori successivi, iniziando da str e finendo in other_str incluso, passando ogni valore a turno al blocco. Il metodo String # succ viene utilizzato per generare ogni valore. |
Direttive di decompressione delle stringhe
Direttiva | ritorna | Descrizione |
---|---|---|
UN | Corda | Con i valori nulli finali e gli spazi rimossi. |
un | Corda | Corda. |
B | Corda | Estrae bit da ogni carattere (prima il bit più significativo). |
b | Corda | Estrae bit da ogni carattere (prima il bit meno significativo). |
C | Fixnum | Estrae un carattere come numero intero senza segno. |
c | Fixnum | Estrae un carattere come numero intero. |
D, d | Galleggiante | Tratta sizeof (double) caratteri come un double nativo. |
E | Galleggiante | Tratta la dimensione dei caratteri (doppi) come un doppio nell'ordine dei byte littleendian. |
e | Galleggiante | Tratta la dimensione dei caratteri (float) come un float nell'ordine dei byte littleendian. |
F, f | Galleggiante | Tratta i caratteri sizeof (float) come un float nativo. |
G | Galleggiante | Considera la dimensione dei caratteri (doppi) come un doppio nell'ordine dei byte di rete. |
g | Corda | Considera la dimensione dei caratteri (float) come un float nell'ordine dei byte di rete. |
H | Corda | Estrae bocconcini esadecimali da ogni personaggio (prima il bit più significativo) |
h | Corda | Estrae bocconcini esadecimali da ogni personaggio (prima il bit meno significativo). |
io | Numero intero | Considera sizeof (int) (modificato da _) i caratteri successivi come un numero intero nativo senza segno. |
io | Numero intero | Considera sizeof (int) (modificato da _) i caratteri successivi come un intero nativo con segno. |
L | Numero intero | Tratta quattro caratteri successivi (modificati da _) come un intero lungo nativo senza segno. |
l | Numero intero | Tratta quattro caratteri successivi (modificati da _) come un intero lungo nativo con segno. |
M | Corda | Quotato stampabile. |
m | Corda | Codifica Base64. |
N | Numero intero | Considera quattro caratteri come un long senza segno nell'ordine dei byte di rete. |
n | Fixnum | Considera due caratteri come un corto senza segno nell'ordine dei byte di rete. |
P | Corda | Tratta i caratteri sizeof (char *) come un puntatore e restituisce i caratteri \ emph {len} dalla posizione di riferimento. |
p | Corda | Considera sizeof (char *) caratteri come un puntatore a una stringa con terminazione null. |
Q | Numero intero | Considera otto caratteri come una parola quadrupla senza segno (64 bit). |
q | Numero intero | Tratta otto caratteri come una parola quadrupla con segno (64 bit). |
S | Fixnum | Tratta due caratteri successivi (diversi se utilizzati _) come abbreviazioni senza segno nell'ordine dei byte nativo. |
S | Fixnum | Tratta due caratteri successivi (diversi se utilizzato _) come abbreviazioni con segno nell'ordine dei byte nativo. |
U | Numero intero | Caratteri UTF-8 come numeri interi senza segno. |
u | Corda | Codifica UU. |
V | Fixnum | Tratta quattro caratteri come un long senza segno in ordine di byte little-endian. |
v | Fixnum | Tratta due caratteri come uno short senza segno in ordine di byte little-endian. |
w | Numero intero | Intero compresso con BER. |
X | Salta indietro di un carattere. | |
X | Salta in avanti di un carattere. | |
Z | Corda | Con i valori nulli finali rimossi fino al primo nullo con *. |
@ | Salta all'offset fornito dall'argomento length. |
Esempio
Prova il seguente esempio per decomprimere vari dati.
"abc \0\0abc \0\0".unpack('A6Z6') #=> ["abc", "abc "]
"abc \0\0".unpack('a3a3') #=> ["abc", " \000\000"]
"abc \0abc \0".unpack('Z*Z*') #=> ["abc ", "abc "]
"aa".unpack('b8B8') #=> ["10000110", "01100001"]
"aaa".unpack('h2H2c') #=> ["16", "61", 97]
"\xfe\xff\xfe\xff".unpack('sS') #=> [-2, 65534]
"now = 20is".unpack('M*') #=> ["now is"]
"whole".unpack('xax2aX2aX1aX2a') #=> ["h", "e", "l", "l", "o"]
Gli array Ruby sono raccolte ordinate e indicizzate con interi di qualsiasi oggetto. Ogni elemento in un array è associato e a cui fa riferimento un indice.
L'indicizzazione degli array inizia da 0, come in C o Java. Si presume un indice negativo relativo alla fine dell'array, ovvero un indice -1 indica l'ultimo elemento dell'array, -2 è il penultimo elemento dell'array e così via.
Gli array Ruby possono contenere oggetti come String, Integer, Fixnum, Hash, Symbol e persino altri oggetti Array. Gli array Ruby non sono rigidi come gli array in altre lingue. Gli array Ruby crescono automaticamente mentre vengono aggiunti elementi.
Creazione di array
Esistono molti modi per creare o inizializzare un array. Un modo è con il nuovo metodo di classe:
names = Array.new
È possibile impostare la dimensione di un array al momento della creazione dell'array -
names = Array.new(20)
I nomi degli array ora hanno una dimensione o una lunghezza di 20 elementi. Puoi restituire la dimensione di un array con i metodi size o length -
#!/usr/bin/ruby
names = Array.new(20)
puts names.size # This returns 20
puts names.length # This also returns 20
Questo produrrà il seguente risultato:
20
20
È possibile assegnare un valore a ciascun elemento dell'array come segue:
#!/usr/bin/ruby
names = Array.new(4, "mac")
puts "#{names}"
Questo produrrà il seguente risultato:
["mac", "mac", "mac", "mac"]
Puoi anche usare un blocco con new, popolando ogni elemento con ciò che il blocco valuta -
#!/usr/bin/ruby
nums = Array.new(10) { |e| e = e * 2 }
puts "#{nums}"
Questo produrrà il seguente risultato:
[0, 2, 4, 6, 8, 10, 12, 14, 16, 18]
C'è un altro metodo di Array, []. Funziona così -
nums = Array.[](1, 2, 3, 4,5)
Un'altra forma di creazione di array è la seguente:
nums = Array[1, 2, 3, 4,5]
Il modulo Kernel disponibile nel core Ruby ha un metodo Array, che accetta solo un singolo argomento. Qui, il metodo accetta un intervallo come argomento per creare un array di cifre:
#!/usr/bin/ruby
digits = Array(0..9)
puts "#{digits}"
Questo produrrà il seguente risultato:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
Metodi integrati negli array
Abbiamo bisogno di un'istanza dell'oggetto Array per chiamare un metodo Array. Come abbiamo visto, di seguito è riportato il modo per creare un'istanza dell'oggetto Array:
Array.[](...) [or] Array[...] [or] [...]
Ciò restituirà un nuovo array popolato con gli oggetti dati. Ora, utilizzando l'oggetto creato, possiamo chiamare qualsiasi metodo di istanza disponibile. Ad esempio:
#!/usr/bin/ruby
digits = Array(0..9)
num = digits.at(6)
puts "#{num}"
Questo produrrà il seguente risultato:
6
Sr.No. | Metodi e descrizione |
---|---|
1 | array & other_array Restituisce un nuovo array contenente elementi comuni ai due array, senza duplicati. |
2 | array * int [or] array * str Restituisce un nuovo array costruito concatenando le copie int di self. Con un argomento String, equivalente a self.join (str). |
3 | array + other_array Restituisce un nuovo array costruito concatenando i due array insieme per produrre un terzo array. |
4 | array - other_array Restituisce un nuovo array che è una copia dell'array originale, rimuovendo tutti gli elementi che appaiono anche in other_array. |
5 | array <=> other_array Confronta str con other_str, restituendo -1 (minore di), 0 (uguale) o 1 (maggiore di). Il confronto fa distinzione tra maiuscole e minuscole. |
6 | array | other_array Restituisce un nuovo array unendo array con other_array, rimuovendo i duplicati. |
7 | array << obj Spinge l'oggetto dato alla fine dell'array. Questa espressione restituisce l'array stesso, quindi più aggiunte possono essere concatenate insieme. |
8 | array <=> other_array Restituisce un numero intero (-1, 0 o +1) se questo array è minore, uguale o maggiore di other_array. |
9 | array == other_array Due array sono uguali se contengono lo stesso numero di elementi e se ogni elemento è uguale (secondo Object. ==) l'elemento corrispondente nell'altro array. |
10 | array[index] [or] array[start, length] [or] array[range] [or] array.slice(index) [or] array.slice(start, length) [or] array.slice(range) Restituisce l'elemento all'indice o restituisce un sottoarray a partire dall'inizio e continua per gli elementi length , oppure restituisce un sottoarray specificato da range . Gli indici negativi contano all'indietro dalla fine della matrice (-1 è l'ultimo elemento). Restituisce zero se l'indice (o l'indice iniziale) è fuori intervallo. |
11 | array[index] = obj [or] array[start, length] = obj or an_array or nil [or] array[range] = obj or an_array or nil Imposta l'elemento in corrispondenza dell'indice o sostituisce un sottoarray a partire dall'inizio e continua per gli elementi length , oppure sostituisce un sottoarray specificato da range . Se gli indici sono maggiori della capacità corrente dell'array, l'array cresce automaticamente. Gli indici negativi verranno conteggiati all'indietro dalla fine della matrice. Inserisce elementi se la lunghezza è zero. Se nil viene utilizzato nella seconda e terza forma, elimina gli elementi da self . |
12 | array.abbrev(pattern = nil) Calcola l'insieme di abbreviazioni non ambigue per le stringhe in self . Se viene passato un pattern o una stringa, vengono considerate solo le stringhe che corrispondono al pattern o che iniziano con la stringa. |
13 | array.assoc(obj) Cerca in un array i cui elementi sono anche array che confrontano obj con il primo elemento di ogni array contenuto utilizzando obj. ==. Restituisce il primo array contenuto che corrisponde o nullo se non viene trovata alcuna corrispondenza. |
14 | array.at(index) Restituisce l'elemento in corrispondenza dell'indice. Un indice negativo conta dalla fine del sé. Restituisce zero se l'indice è fuori intervallo. |
15 | array.clear Rimuove tutti gli elementi dall'array. |
16 | array.collect { |item| block } [or] array.map { |item| block } Invoca il blocco una volta per ogni elemento del sé . Crea un nuovo array contenente i valori restituiti dal blocco. |
17 | array.collect! { |item| block } [or] array.map! { |item| block } Richiama block una volta per ogni elemento di self , sostituendo l'elemento con il valore restituito da block . |
18 | array.compact Restituisce una copia di self con tutti gli elementi nulli rimossi. |
19 | array.compact! Rimuove gli elementi nulli dall'array. Restituisce zero se non sono state apportate modifiche. |
20 | array.concat(other_array) Aggiunge gli elementi in other_array a self . |
21 | array.delete(obj) [or] array.delete(obj) { block } Elimina gli elementi da self che sono uguali a obj . Se l'articolo non viene trovato, restituisce zero . Se viene fornito il blocco di codice opzionale , restituisce il risultato del blocco se l'elemento non viene trovato. |
22 | array.delete_at(index) Elimina l'elemento in corrispondenza dell'indice specificato , restituendo quell'elemento o nil se l'indice è fuori intervallo. |
23 | array.delete_if { |item| block } Elimina ogni elemento di self per il quale il blocco restituisce true. |
24 | array.each { |item| block } Chiama block una volta per ogni elemento in self , passando quell'elemento come parametro. |
25 | array.each_index { |index| block } Uguale a Array # ciascuno, ma passa l' indice dell'elemento invece dell'elemento stesso. |
26 | array.empty? Restituisce vero se l'array self non contiene elementi. |
27 | array.eql?(other) Restituisce vero se array e altri sono lo stesso oggetto o sono entrambi array con lo stesso contenuto. |
28 | array.fetch(index) [or] array.fetch(index, default) [or] array.fetch(index) { |index| block } Tenta di restituire l'elemento nella posizione di indice . Se index si trova al di fuori dell'array, la prima forma genera un'eccezione IndexError , la seconda forma restituisce default e la terza forma restituisce il valore di invocare il blocco , passando l' indice . Valori negativi del conteggio dell'indice dalla fine della matrice. |
29 | array.fill(obj) [or] array.fill(obj, start [, length]) [or] array.fill(obj, range) [or] array.fill { |index| block } [or] array.fill(start [, length] ) { |index| block } [or] array.fill(range) { |index| block } Le prime tre forme impostano gli elementi selezionati del sé su obj . Un inizio di zero è uguale a zero. Una lunghezza pari a zero è equivalente a self.length . Le ultime tre forme riempiono la matrice con il valore del blocco. Il blocco viene passato con l'indice assoluto di ogni elemento da riempire. |
30 | array.first [or] array.first(n) Restituisce il primo elemento, oi primi n elementi, della matrice. Se l'array è vuoto, il primo modulo restituisce nil e il secondo modulo restituisce un array vuoto. |
31 | array.flatten Restituisce un nuovo array che è un appiattimento unidimensionale di questo array (in modo ricorsivo). |
32 | array.flatten! Appiattisce l' array in posizione. Restituisce zero se non sono state apportate modifiche. (l'array non contiene sottoarray.) |
33 | array.frozen? Restituisce vero se l' array è congelato (o temporaneamente congelato durante l'ordinamento). |
34 | array.hash Calcola un codice hash per array. Due array con lo stesso contenuto avranno lo stesso codice hash. |
35 | array.include?(obj) Restituisce vero se obj è presente in self , falso in caso contrario. |
36 | array.index(obj) Restituisce l' indice del primo oggetto in self che è == in obj. Restituisce zero se non viene trovata alcuna corrispondenza. |
37 | array.indexes(i1, i2, ... iN) [or] array.indices(i1, i2, ... iN) Questo metodo è deprecato nell'ultima versione di Ruby, quindi usa Array # values_at. |
38 | array.indices(i1, i2, ... iN) [or] array.indexes(i1, i2, ... iN) Questo metodo è deprecato nell'ultima versione di Ruby, quindi usa Array # values_at. |
39 | array.insert(index, obj...) Inserisce i valori dati prima dell'elemento con l' indice specificato (che può essere negativo). |
40 | array.inspect Crea una versione stampabile dell'array. |
41 | array.join(sep = $,) Restituisce una stringa creata convertendo ogni elemento dell'array in una stringa, separata da sep . |
42 | array.last [or] array.last(n) Restituisce l'ultimo o gli ultimi elementi di self . Se array è vuoto , la prima forma restituisce nil . |
43 | array.length Restituisce il numero di elementi in self . Può essere zero. |
44 | array.map { |item| block } [or] array.collect { |item| block } Invoca il blocco una volta per ogni elemento del sé . Crea un nuovo array contenente i valori restituiti dal blocco. |
45 | array.map! { |item| block } [or] array.collect! { |item| block } Richiama il blocco una volta per ogni elemento dell'array , sostituendo l'elemento con il valore restituito dal blocco. |
46 | array.nitems Restituisce il numero di elementi non nulli in self . Può essere zero. |
47 | array.pack(aTemplateString) Comprime il contenuto della matrice in una sequenza binaria in base alle direttive in TemplateString. Le direttive A, a e Z possono essere seguite da un conteggio, che fornisce la larghezza del campo risultante. Anche le restanti direttive possono richiedere un conteggio, indicando il numero di elementi dell'array da convertire. Se il conteggio è un asterisco (*), tutti gli elementi rimanenti dell'array verranno convertiti. Qualsiasi direttiva è ancora può essere seguita da un trattino basso (_) per utilizzare la dimensione nativa della piattaforma sottostante per il tipo specificato; altrimenti, usano una dimensione indipendente dalla piattaforma. Gli spazi vengono ignorati nella stringa del modello. |
48 | array.pop Rimuove l'ultimo elemento dall'array e lo restituisce, o nil se l' array è vuoto. |
49 | array.push(obj, ...) Inserisce (aggiunge) l'oggetto dato alla fine di questo array. Questa espressione restituisce l'array stesso, quindi più aggiunte possono essere concatenate insieme. |
50 | array.rassoc(key) Esegue la ricerca nell'array i cui elementi sono anche array. Confronta la chiave con il secondo elemento di ogni matrice contenuta utilizzando ==. Restituisce il primo array contenuto che corrisponde. |
51 | array.reject { |item| block } Restituisce un nuovo array contenente l' array di elementi per il quale il blocco non è vero . |
52 | array.reject! { |item| block } Elimina gli elementi dall'array per i quali il blocco restituisce true , ma restituisce zero se non sono state apportate modifiche. Equivalente a Array # delete_if. |
53 | array.replace(other_array) Sostituisce il contenuto di array con il contenuto di other_array , troncandolo o espandendolo se necessario. |
54 | array.reverse Restituisce un nuovo array contenente gli elementi dell'array in ordine inverso. |
55 | array.reverse! Inverte l' array in posizione. |
56 | array.reverse_each {|item| block } Uguale a Array # ciascuno, ma attraversa l' array in ordine inverso. |
57 | array.rindex(obj) Restituisce l'indice dell'ultimo oggetto nell'array == in obj. Restituisce zero se non viene trovata alcuna corrispondenza. |
58 | array.select {|item| block } Richiama il blocco che passa in elementi successivi da array, restituendo un array contenente quegli elementi per i quali il blocco restituisce un valore vero . |
59 | array.shift Restituisce il primo elemento di self e lo rimuove (spostando tutti gli altri elementi verso il basso di uno). Restituisce zero se l'array è vuoto. |
60 | array.size Restituisce la lunghezza della matrice (numero di elementi). Alias per lunghezza. |
61 | array.slice(index) [or] array.slice(start, length) [or] array.slice(range) [or] array[index] [or] array[start, length] [or] array[range] Restituisce l'elemento all'indice o restituisce un sottoarray a partire dall'inizio e continua per gli elementi length , oppure restituisce un sottoarray specificato da range . Gli indici negativi contano all'indietro dalla fine della matrice (-1 è l'ultimo elemento). Restituisce zero se l' indice (o l'indice iniziale) è fuori intervallo. |
62 | array.slice!(index) [or] array.slice!(start, length) [or] array.slice!(range) Elimina gli elementi forniti da un indice (opzionalmente con una lunghezza) o da un intervallo . Restituisce l'oggetto eliminato, il sottoarray o nil se index è fuori intervallo. |
63 | array.sort [or] array.sort { | a,b | block } Restituisce un nuovo array creato ordinando self. |
64 | array.sort! [or] array.sort! { | a,b | block } Ordina se stesso. |
65 | array.to_a Restituisce se stesso . Se chiamato in una sottoclasse di Array , converte il ricevitore in un oggetto Array. |
66 | array.to_ary Restituisce se stesso. |
67 | array.to_s Restituisce self.join. |
68 | array.transpose Presume che self sia un array di array e traspone le righe e le colonne. |
69 | array.uniq Restituisce un nuovo array rimuovendo i valori duplicati nell'array . |
70 | array.uniq! Rimuove gli elementi duplicati da sé . Restituisce zero se non vengono apportate modifiche (ovvero, non vengono trovati duplicati). |
71 | array.unshift(obj, ...) Antepone gli oggetti in primo piano all'array, gli altri in primo piano. |
72 | array.values_at(selector,...) Restituisce un array contenente gli elementi in self corrispondenti al selettore dato (uno o più). I selettori possono essere indici o intervalli interi. |
73 | array.zip(arg, ...) [or] array.zip(arg, ...){ | arr | block } Converte qualsiasi argomento in array, quindi unisce gli elementi dell'array con gli elementi corrispondenti di ogni argomento. |
Direttive sui pacchetti di array
Sr.No. | Direttiva e descrizione |
---|---|
1 | @ Si sposta in posizione assoluta. |
2 | A Stringa ASCII (spazio riempito, il conteggio è la larghezza). |
3 | a Stringa ASCII (con riempimento nullo, il conteggio è la larghezza). |
4 | B stringa (ordine di bit decrescente). |
5 | b Stringa di bit (ordine di bit crescente). |
6 | C Carattere non firmato |
7 | c Char. |
8 | D, d Float a doppia precisione, formato nativo. |
9 | E Float a doppia precisione, ordine dei byte little-endian. |
10 | e Float a precisione singola, ordine dei byte little-endian. |
11 | F, f Float a precisione singola, formato nativo. |
12 | G Float a doppia precisione, ordine byte di rete (big-endian). |
13 | g Float a precisione singola, ordine byte di rete (big-endian). |
14 | H Stringa esadecimale (prima il bocconcino alto). |
15 | h Stringa esadecimale (prima il morso basso). |
16 | I Numero intero senza segno. |
17 | i Numero intero. |
18 | L Non firmato a lungo. |
19 | l Lungo. |
20 | M Citato stampabile, codifica MIME (vedere RFC 2045). |
21 | m Stringa con codifica Base64. |
22 | N Ordine byte lungo, rete (big-endian). |
23 | n Ordine byte breve, rete (big-endian). |
24 | P Puntatore a una struttura (stringa di lunghezza fissa). |
25 | p Puntatore a una stringa con terminazione null. |
26 | Q, q Numero a 64 bit. |
27 | S Corto non firmato. |
28 | s Corto. |
29 | U UTF-8. |
30 | u Stringa con codifica UU. |
31 | V Ordine dei byte lungo, little endian. |
32 | v Ordine dei byte corto, little endian. |
33 | w Intero compresso BER \ fnm. |
34 | X Eseguire il backup di un byte. |
35 | x Byte nullo. |
36 | Z Uguale a a, tranne per il fatto che null viene aggiunto con *. |
Esempio
Prova il seguente esempio per impacchettare vari dati.
a = [ "a", "b", "c" ]
n = [ 65, 66, 67 ]
puts a.pack("A3A3A3") #=> "a b c "
puts a.pack("a3a3a3") #=> "a\000\000b\000\000c\000\000"
puts n.pack("ccc") #=> "ABC"
Questo produrrà il seguente risultato:
a b c
abc
ABC
Un hash è una raccolta di coppie chiave-valore come questa: "dipendente" => "stipendio". È simile a un array, tranne per il fatto che l'indicizzazione viene eseguita tramite chiavi arbitrarie di qualsiasi tipo di oggetto, non un indice intero.
L'ordine in cui attraversi un hash per chiave o valore può sembrare arbitrario e generalmente non sarà nell'ordine di inserimento. Se tenti di accedere a un hash con una chiave che non esiste, il metodo restituirà nil .
Creazione di hash
Come con gli array, esiste una varietà di modi per creare hash. Puoi creare un hash vuoto con il nuovo metodo di classe -
months = Hash.new
Puoi anche usare new per creare un hash con un valore predefinito, che altrimenti è solo nullo -
months = Hash.new( "month" )
or
months = Hash.new "month"
Quando accedi a qualsiasi chiave in un hash che ha un valore predefinito, se la chiave o il valore non esiste, l'accesso all'hash restituirà il valore predefinito -
#!/usr/bin/ruby
months = Hash.new( "month" )
puts "#{months[0]}"
puts "#{months[72]}"
Questo produrrà il seguente risultato:
month
month
#!/usr/bin/ruby
H = Hash["a" => 100, "b" => 200]
puts "#{H['a']}"
puts "#{H['b']}"
Questo produrrà il seguente risultato:
100
200
Puoi usare qualsiasi oggetto Ruby come chiave o valore, anche un array, quindi il seguente esempio è valido:
[1,"jan"] => "January"
Metodi incorporati di hash
Abbiamo bisogno di un'istanza dell'oggetto Hash per chiamare un metodo Hash. Come abbiamo visto, di seguito è riportato il modo per creare un'istanza dell'oggetto Hash:
Hash[[key =>|, value]* ] or
Hash.new [or] Hash.new(obj) [or]
Hash.new { |hash, key| block }
Questo restituirà un nuovo hash popolato con gli oggetti dati. Ora utilizzando l'oggetto creato, possiamo chiamare qualsiasi metodo di istanza disponibile. Ad esempio:
#!/usr/bin/ruby
$, = ", "
months = Hash.new( "month" )
months = {"1" => "January", "2" => "February"}
keys = months.keys
puts "#{keys}"
Questo produrrà il seguente risultato:
["1", "2"]
Di seguito sono riportati i metodi hash pubblici (supponendo che hash sia un oggetto array):
Sr.No. | Metodi e descrizione |
---|---|
1 | hash == other_hash Verifica se due hash sono uguali, in base al fatto che abbiano lo stesso numero di coppie chiave-valore e se le coppie chiave-valore corrispondono alla coppia corrispondente in ogni hash. |
2 | hash.[key] Utilizzando una chiave, fa riferimento a un valore da hash. Se la chiave non viene trovata, restituisce un valore predefinito. |
3 | hash.[key] = value Associa il valore dato da valore con la chiave data da chiave . |
4 | hash.clear Rimuove tutte le coppie chiave-valore da hash. |
5 | hash.default(key = nil) Restituisce il valore predefinito per hash , nil se non impostato di default =. ([] restituisce un valore predefinito se la chiave non esiste in hash .) |
6 | hash.default = obj Imposta un valore predefinito per hash . |
7 | hash.default_proc Restituisce un blocco se l' hash è stato creato da un blocco. |
8 | hash.delete(key) [or] array.delete(key) { |key| block } Elimina una coppia chiave-valore da hash per chiave . Se viene utilizzato blocco, restituisce il risultato di un blocco se la coppia non viene trovata. Confronta delete_if . |
9 | hash.delete_if { |key,value| block } Elimina una coppia chiave-valore da hash per ogni coppia che il blocco restituisce come vera . |
10 | hash.each { |key,value| block } Itera su hash , chiamando il blocco una volta per ogni chiave, passando il valore-chiave come matrice a due elementi. |
11 | hash.each_key { |key| block } Itera su hash , chiamando il blocco una volta per ogni chiave, passando la chiave come parametro. |
12 | hash.each_key { |key_value_array| block } Itera su hash , chiamando il blocco una volta per ogni chiave , passando la chiave e il valore come parametri. |
13 | hash.each_key { |value| block } Itera su hash , chiamando il blocco una volta per ogni chiave , passando il valore come parametro. |
14 | hash.empty? Verifica se l'hash è vuoto (non contiene coppie chiave-valore) e restituisce vero o falso . |
15 | hash.fetch(key [, default] ) [or] hash.fetch(key) { | key | block } Restituisce un valore da hash per la chiave data . Se la chiave non può essere trovata e non ci sono altri argomenti, solleva un'eccezione IndexError ; se viene fornito il valore predefinito , viene restituito; se viene specificato il blocco opzionale, viene restituito il suo risultato. |
16 | hash.has_key?(key) [or] hash.include?(key) [or] hash.key?(key) [or] hash.member?(key) Verifica se una determinata chiave è presente nell'hash, restituendo vero o falso . |
17 | hash.has_value?(value) Verifica se l'hash contiene il valore specificato . |
18 | hash.index(value) Restituisce la chiave per il valore dato in hash, nil se non viene trovato alcun valore corrispondente. |
19 | hash.indexes(keys) Restituisce un nuovo array costituito da valori per le chiavi fornite. Inserirà il valore predefinito per le chiavi che non vengono trovate. Questo metodo è deprecato. Usa seleziona. |
20 | hash.indices(keys) Restituisce un nuovo array costituito da valori per le chiavi fornite. Inserirà il valore predefinito per le chiavi che non vengono trovate. Questo metodo è deprecato. Usa seleziona. |
21 | hash.inspect Restituisce una bella versione di stringa di stampa di hash. |
22 | hash.invert Crea un nuovo hash , invertendo chiavi e valori da hash ; ovvero, nel nuovo hash, le chiavi dell'hash diventano valori e i valori diventano chiavi. |
23 | hash.keys Crea un nuovo array con chiavi da hash . |
24 | hash.length Restituisce la dimensione o la lunghezza dell'hash come numero intero. |
25 | hash.merge(other_hash) [or] hash.merge(other_hash) { |key, oldval, newval| block } Restituisce un nuovo hash contenente il contenuto di hash e other_hash , sovrascrivendo le coppie in hash con chiavi duplicate con quelle di other_hash . |
26 | hash.merge!(other_hash) [or] hash.merge!(other_hash) { |key, oldval, newval| block } Uguale all'unione, ma le modifiche vengono apportate sul posto. |
27 | hash.rehash Ricostruisce l' hash in base ai valori correnti per ogni chiave . Se i valori sono cambiati da quando sono stati inseriti, questo metodo reindicizza l' hash . |
28 | hash.reject { |key, value| block } Crea un nuovo hash per ogni coppia che il blocco valuta come true |
29 | hash.reject! { |key, value| block } Uguale al rifiuto , ma le modifiche vengono apportate sul posto. |
30 | hash.replace(other_hash) Sostituisce il contenuto di hash con il contenuto di other_hash . |
31 | hash.select { |key, value| block } Restituisce un nuovo array costituito da coppie chiave-valore da hash per cui il blocco restituisce true . |
32 | hash.shift Rimuove una coppia chiave-valore da hash , restituendola come un array di due elementi. |
33 | hash.size Restituisce la dimensione o la lunghezza dell'hash come numero intero. |
34 | hash.sort Converte l' hash in un array bidimensionale contenente array di coppie chiave-valore, quindi lo ordina come array. |
35 | hash.store(key, value) Memorizza una coppia chiave-valore in hash . |
36 | hash.to_a Crea un array bidimensionale da hash. Ogni coppia chiave / valore viene convertita in un array e tutti questi array vengono archiviati in un array contenitore. |
37 | hash.to_hash Restituisce hash (self). |
38 | hash.to_s Converte l' hash in un array, quindi converte quell'array in una stringa. |
39 | hash.update(other_hash) [or] hash.update(other_hash) {|key, oldval, newval| block} Restituisce un nuovo hash contenente il contenuto di hash e other_hash , sovrascrivendo le coppie in hash con chiavi duplicate con quelle di other_hash . |
40 | hash.value?(value) Verifica se l' hash contiene il valore specificato . |
41 | hash.values Restituisce un nuovo array contenente tutti i valori di hash . |
42 | hash.values_at(obj, ...) Restituisce un nuovo array contenente i valori di hash associati alla chiave o alle chiavi fornite. |
Il Timeclass rappresenta le date e le ore in Ruby. È uno strato sottile sulla funzionalità di data e ora del sistema fornita dal sistema operativo. Questa classe potrebbe non essere in grado di rappresentare date prima del 1970 o dopo il 2038 sul tuo sistema.
Questo capitolo ti rende familiare con tutti i concetti più ricercati di data e ora.
Ottenere la data e l'ora correnti
Di seguito è riportato il semplice esempio per ottenere la data e l'ora correnti:
#!/usr/bin/ruby -w
time1 = Time.new
puts "Current Time : " + time1.inspect
# Time.now is a synonym:
time2 = Time.now
puts "Current Time : " + time2.inspect
Questo produrrà il seguente risultato:
Current Time : Mon Jun 02 12:02:39 -0700 2008
Current Time : Mon Jun 02 12:02:39 -0700 2008
Recupero dei componenti di una data e ora
Possiamo usare l' oggetto Time per ottenere vari componenti di data e ora. Di seguito è riportato l'esempio che mostra lo stesso:
#!/usr/bin/ruby -w
time = Time.new
# Components of a Time
puts "Current Time : " + time.inspect
puts time.year # => Year of the date
puts time.month # => Month of the date (1 to 12)
puts time.day # => Day of the date (1 to 31 )
puts time.wday # => 0: Day of week: 0 is Sunday
puts time.yday # => 365: Day of year
puts time.hour # => 23: 24-hour clock
puts time.min # => 59
puts time.sec # => 59
puts time.usec # => 999999: microseconds
puts time.zone # => "UTC": timezone name
Questo produrrà il seguente risultato:
Current Time : Mon Jun 02 12:03:08 -0700 2008
2008
6
2
1
154
12
3
8
247476
UTC
Funzioni Time.utc, Time.gm e Time.local
Queste due funzioni possono essere utilizzate per formattare la data in un formato standard come segue:
# July 8, 2008
Time.local(2008, 7, 8)
# July 8, 2008, 09:10am, local time
Time.local(2008, 7, 8, 9, 10)
# July 8, 2008, 09:10 UTC
Time.utc(2008, 7, 8, 9, 10)
# July 8, 2008, 09:10:11 GMT (same as UTC)
Time.gm(2008, 7, 8, 9, 10, 11)
Di seguito è riportato l'esempio per ottenere tutti i componenti in un array nel seguente formato:
[sec,min,hour,day,month,year,wday,yday,isdst,zone]
Prova quanto segue:
#!/usr/bin/ruby -w
time = Time.new
values = time.to_a
p values
Questo genererà il seguente risultato:
[26, 10, 12, 2, 6, 2008, 1, 154, false, "MST"]
Questo array potrebbe essere passato alle funzioni Time.utc o Time.local per ottenere diversi formati di date come segue:
#!/usr/bin/ruby -w
time = Time.new
values = time.to_a
puts Time.utc(*values)
Questo genererà il seguente risultato:
Mon Jun 02 12:15:36 UTC 2008
Di seguito è riportato il modo per ottenere il tempo rappresentato internamente come secondi dall'epoca (dipendente dalla piattaforma):
# Returns number of seconds since epoch
time = Time.now.to_i
# Convert number of seconds into Time object.
Time.at(time)
# Returns second since epoch which includes microseconds
time = Time.now.to_f
Fusi orari e ora legale
È possibile utilizzare un oggetto Time per ottenere tutte le informazioni relative ai fusi orari e all'ora legale come segue:
time = Time.new
# Here is the interpretation
time.zone # => "UTC": return the timezone
time.utc_offset # => 0: UTC is 0 seconds offset from UTC
time.zone # => "PST" (or whatever your timezone is)
time.isdst # => false: If UTC does not have DST.
time.utc? # => true: if t is in UTC time zone
time.localtime # Convert to local timezone.
time.gmtime # Convert back to UTC.
time.getlocal # Return a new Time object in local zone
time.getutc # Return a new Time object in UTC
Formattazione di orari e date
Esistono vari modi per formattare la data e l'ora. Ecco un esempio che mostra alcuni:
#!/usr/bin/ruby -w
time = Time.new
puts time.to_s
puts time.ctime
puts time.localtime
puts time.strftime("%Y-%m-%d %H:%M:%S")
Questo produrrà il seguente risultato:
Mon Jun 02 12:35:19 -0700 2008
Mon Jun 2 12:35:19 2008
Mon Jun 02 12:35:19 -0700 2008
2008-06-02 12:35:19
Direttive di formattazione dell'ora
Queste direttive nella tabella seguente vengono utilizzate con il metodo Time.strftime .
Sr.No. | Direttiva e descrizione |
---|---|
1 | %a Il nome abbreviato del giorno della settimana (Sun). |
2 | %A Il nome completo del giorno della settimana (domenica). |
3 | %b Il nome del mese abbreviato (Jan). |
4 | %B Il nome completo del mese (gennaio). |
5 | %c La rappresentazione locale di data e ora preferita. |
6 | %d Giorno del mese (da 01 a 31). |
7 | %H Ora del giorno, formato 24 ore (da 00 a 23). |
8 | %I Ora del giorno, orologio a 12 ore (da 01 a 12). |
9 | %j Giorno dell'anno (da 001 a 366). |
10 | %m Mese dell'anno (da 01 a 12). |
11 | %M Minuto dell'ora (da 00 a 59). |
12 | %p Indicatore meridiano (AM o PM). |
13 | %S Secondo del minuto (da 00 a 60). |
14 | %U Numero della settimana dell'anno corrente, a partire dalla prima domenica come primo giorno della prima settimana (da 00 a 53). |
15 | %W Numero della settimana dell'anno corrente, a partire dal primo lunedì come primo giorno della prima settimana (da 00 a 53). |
16 | %w Giorno della settimana (la domenica è 0, da 0 a 6). |
17 | %x Rappresentanza preferita solo per la data, nessun tempo. |
18 | %X Rappresentanza preferita solo per il tempo, nessuna data. |
19 | %y Anno senza secolo (da 00 a 99). |
20 | %Y Anno con secolo. |
21 | %Z Nome del fuso orario. |
22 | %% Carattere letterale%. |
Aritmetica del tempo
Puoi eseguire semplici operazioni aritmetiche con il tempo come segue:
now = Time.now # Current time
puts now
past = now - 10 # 10 seconds ago. Time - number => Time
puts past
future = now + 10 # 10 seconds from now Time + number => Time
puts future
diff = future - past # => 10 Time - Time => number of seconds
puts diff
Questo produrrà il seguente risultato:
Thu Aug 01 20:57:05 -0700 2013
Thu Aug 01 20:56:55 -0700 2013
Thu Aug 01 20:57:15 -0700 2013
20.0
Gli intervalli si verificano ovunque: da gennaio a dicembre, da 0 a 9, righe da 50 a 67 e così via. Ruby supporta le gamme e ci consente di utilizzare le gamme in una varietà di modi:
- Intervalli come sequenze
- Intervalli come condizioni
- Intervalli come intervalli
Intervalli come sequenze
Il primo e forse il più naturale uso degli intervalli è esprimere una sequenza. Le sequenze hanno un punto iniziale, un punto finale e un modo per produrre valori successivi nella sequenza.
Ruby crea queste sequenze usando il ''..'' e ''...''operatori di intervallo. Il modulo a due punti crea un intervallo inclusivo, mentre il modulo a tre punti crea un intervallo che esclude il valore alto specificato.
(1..5) #==> 1, 2, 3, 4, 5
(1...5) #==> 1, 2, 3, 4
('a'..'d') #==> 'a', 'b', 'c', 'd'
La sequenza 1..100 viene mantenuta come un oggetto Range contenente riferimenti a due oggetti Fixnum . Se necessario, puoi convertire un intervallo in un elenco utilizzando il metodo to_a . Prova il seguente esempio:
#!/usr/bin/ruby
$, =", " # Array value separator
range1 = (1..10).to_a
range2 = ('bar'..'bat').to_a
puts "#{range1}"
puts "#{range2}"
Questo produrrà il seguente risultato:
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
["bar", "bas", "bat"]
Gli intervalli implementano metodi che ti consentono di iterarli e testarne i contenuti in vari modi:
#!/usr/bin/ruby
# Assume a range
digits = 0..9
puts digits.include?(5)
ret = digits.min
puts "Min value is #{ret}"
ret = digits.max
puts "Max value is #{ret}"
ret = digits.reject {|i| i < 5 }
puts "Rejected values are #{ret}"
digits.each do |digit|
puts "In Loop #{digit}"
end
Questo produrrà il seguente risultato:
true
Min value is 0
Max value is 9
Rejected values are 5, 6, 7, 8, 9
In Loop 0
In Loop 1
In Loop 2
In Loop 3
In Loop 4
In Loop 5
In Loop 6
In Loop 7
In Loop 8
In Loop 9
Intervalli come condizioni
Gli intervalli possono essere utilizzati anche come espressioni condizionali. Ad esempio, il seguente frammento di codice stampa serie di righe dallo standard input, dove la prima riga di ogni serie contiene l' inizio della parola e l'ultima riga la parola finisce -
while gets
print if /start/../end/
end
Gli intervalli possono essere utilizzati nelle istruzioni case -
#!/usr/bin/ruby
score = 70
result = case score
when 0..40 then "Fail"
when 41..60 then "Pass"
when 61..70 then "Pass with Merit"
when 71..100 then "Pass with Distinction"
else "Invalid Score"
end
puts result
Questo produrrà il seguente risultato:
Pass with Merit
Intervalli come intervalli
Un uso finale della gamma versatile è come test a intervalli: vedere se qualche valore rientra nell'intervallo rappresentato dalla gamma. Questo viene fatto usando ===, l'operatore di uguaglianza tra maiuscole e minuscole.
#!/usr/bin/ruby
if ((1..10) === 5)
puts "5 lies in (1..10)"
end
if (('a'..'j') === 'c')
puts "c lies in ('a'..'j')"
end
if (('a'..'j') === 'z')
puts "z lies in ('a'..'j')"
end
Questo produrrà il seguente risultato:
5 lies in (1..10)
c lies in ('a'..'j')
Gli iteratori non sono altro che metodi supportati dalle raccolte . Gli oggetti che memorizzano un gruppo di membri di dati sono chiamati raccolte. In Ruby, gli array e gli hash possono essere definiti raccolte.
Gli iteratori restituiscono tutti gli elementi di una raccolta, uno dopo l'altro. Discuteremo qui due iteratori, ciascuno e collect . Vediamoli in dettaglio.
Ruby ogni Iteratore
L'iteratore each restituisce tutti gli elementi di un array o di un hash.
Sintassi
collection.each do |variable|
code
end
Esegue il codice per ogni elemento nella raccolta . Qui, la raccolta potrebbe essere un array o un hash ruby.
Esempio
#!/usr/bin/ruby
ary = [1,2,3,4,5]
ary.each do |i|
puts i
end
Questo produrrà il seguente risultato:
1
2
3
4
5
Associ sempre ogni iteratore a un blocco. Restituisce ogni valore dell'array, uno per uno, al blocco. Il valore viene memorizzato nella variabilei e quindi visualizzato sullo schermo.
Ruby raccoglie Iterator
L' iteratore collect restituisce tutti gli elementi di una raccolta.
Sintassi
collection = collection.collect
Il metodo collect non deve essere sempre associato a un blocco. Il metodo collect restituisce l'intera raccolta, indipendentemente dal fatto che si tratti di un array o di un hash.
Esempio
#!/usr/bin/ruby
a = [1,2,3,4,5]
b = Array.new
b = a.collect
puts b
Questo produrrà il seguente risultato:
1
2
3
4
5
NOTE- Il metodo collect non è il modo giusto per eseguire la copia tra array. C'è un altro metodo chiamato clone , che dovrebbe essere usato per copiare un array in un altro array.
Normalmente usi il metodo collect quando vuoi fare qualcosa con ciascuno dei valori per ottenere il nuovo array. Ad esempio, questo codice produce un array b contenente 10 volte ogni valore in a .
#!/usr/bin/ruby
a = [1,2,3,4,5]
b = a.collect{|x| 10*x}
puts b
Questo produrrà il seguente risultato:
10
20
30
40
50
Ruby fornisce un intero set di metodi relativi all'I / O implementati nel modulo Kernel. Tutti i metodi di I / O derivano dalla classe IO.
La classe IO fornisce tutti i metodi di base, come read, write, gets, put, readline, getc e printf .
Questo capitolo tratterà tutte le funzioni base di I / O disponibili in Ruby. Per ulteriori funzioni, fare riferimento a Ruby Class IO .
L'istruzione put
Nei capitoli precedenti, hai assegnato valori alle variabili e poi stampato l'output usando l' istruzione put .
L' istruzione put indica al programma di visualizzare il valore memorizzato nella variabile. Questo aggiungerà una nuova riga alla fine di ogni riga che scrive.
Esempio
#!/usr/bin/ruby
val1 = "This is variable one"
val2 = "This is variable two"
puts val1
puts val2
Questo produrrà il seguente risultato:
This is variable one
This is variable two
L'istruzione gets
L' istruzione gets può essere utilizzata per ricevere qualsiasi input dall'utente dalla schermata standard chiamata STDIN.
Esempio
Il codice seguente mostra come usare l'istruzione gets. Questo codice chiederà all'utente di inserire un valore, che verrà memorizzato in una variabile val e infine verrà stampato su STDOUT.
#!/usr/bin/ruby
puts "Enter a value :"
val = gets
puts val
Questo produrrà il seguente risultato:
Enter a value :
This is entered value
This is entered value
La dichiarazione putc
A differenza dell'istruzione put , che visualizza l'intera stringa sullo schermo, l' istruzione putc può essere utilizzata per visualizzare un carattere alla volta.
Esempio
L'output del codice seguente è solo il carattere H -
#!/usr/bin/ruby
str = "Hello Ruby!"
putc str
Questo produrrà il seguente risultato:
H
La dichiarazione di stampa
L' istruzione print è simile all'istruzione put . L'unica differenza è che l' istruzione put va alla riga successiva dopo aver stampato il contenuto, mentre con l' istruzione print il cursore è posizionato sulla stessa riga.
Esempio
#!/usr/bin/ruby
print "Hello World"
print "Good Morning"
Questo produrrà il seguente risultato:
Hello WorldGood Morning
Apertura e chiusura di file
Fino ad ora, hai letto e scritto sullo standard input e output. Ora vedremo come giocare con i file di dati effettivi.
Il metodo File.new
È possibile creare un oggetto File utilizzando il metodo File.new per leggere, scrivere o entrambi, in base alla stringa della modalità. Infine, puoi utilizzare il metodo File.close per chiudere quel file.
Sintassi
aFile = File.new("filename", "mode")
# ... process the file
aFile.close
Il metodo File.open
È possibile utilizzare il metodo File.open per creare un nuovo oggetto file e assegnare tale oggetto file a un file. Tuttavia, esiste una differenza tra i metodi File.open e File.new . La differenza è che il metodo File.open può essere associato a un blocco, mentre non è possibile fare lo stesso utilizzando il metodo File.new .
File.open("filename", "mode") do |aFile|
# ... process the file
end
Sr.No. | Modalità e descrizione |
---|---|
1 | r Modalità di sola lettura. Il puntatore del file viene posizionato all'inizio del file. Questa è la modalità di default. |
2 | r+ Modalità lettura-scrittura. Il puntatore del file sarà all'inizio del file. |
3 | w Modalità di sola scrittura. Sovrascrive il file se il file esiste. Se il file non esiste, crea un nuovo file per la scrittura. |
4 | w+ Modalità lettura-scrittura. Sovrascrive il file esistente se il file esiste. Se il file non esiste, crea un nuovo file per la lettura e la scrittura. |
5 | a Modalità di sola scrittura. Il puntatore del file si trova alla fine del file se il file esiste. Cioè, il file è in modalità di aggiunta. Se il file non esiste, crea un nuovo file per la scrittura. |
6 | a+ Modalità di lettura e scrittura. Il puntatore del file si trova alla fine del file se il file esiste. Il file si apre in modalità di aggiunta. Se il file non esiste, crea un nuovo file per la lettura e la scrittura. |
Lettura e scrittura di file
Gli stessi metodi che abbiamo utilizzato per l'I / O "semplice" sono disponibili per tutti gli oggetti file. Quindi, gets legge una riga dallo standard input e aFile.gets legge una riga dall'oggetto file aFile.
Tuttavia, gli oggetti I / O forniscono un set aggiuntivo di metodi di accesso per semplificarci la vita.
Il metodo sysread
È possibile utilizzare il metodo sysread per leggere il contenuto di un file. È possibile aprire il file in una qualsiasi delle modalità quando si utilizza il metodo sysread. Ad esempio:
Di seguito è riportato il file di testo di input:
This is a simple text file for testing purpose.
Ora proviamo a leggere questo file -
#!/usr/bin/ruby
aFile = File.new("input.txt", "r")
if aFile
content = aFile.sysread(20)
puts content
else
puts "Unable to open file!"
end
Questa istruzione produrrà i primi 20 caratteri del file. Il puntatore del file verrà ora posizionato al ventunesimo carattere del file.
Il metodo syswrite
È possibile utilizzare il metodo syswrite per scrivere il contenuto in un file. È necessario aprire il file in modalità di scrittura quando si utilizza il metodo syswrite. Ad esempio:
#!/usr/bin/ruby
aFile = File.new("input.txt", "r+")
if aFile
aFile.syswrite("ABCDEF")
else
puts "Unable to open file!"
end
Questa istruzione scriverà "ABCDEF" nel file.
Il metodo each_byte
Questo metodo appartiene alla classe File . Il metodo each_byte è sempre associato a un blocco. Considera il seguente codice di esempio:
#!/usr/bin/ruby
aFile = File.new("input.txt", "r+")
if aFile
aFile.syswrite("ABCDEF")
aFile.each_byte {|ch| putc ch; putc ?. }
else
puts "Unable to open file!"
end
I caratteri vengono passati uno ad uno alla variabile ch e quindi visualizzati sullo schermo come segue:
s. .a. .s.i.m.p.l.e. .t.e.x.t. .f.i.l.e. .f.o.r. .t.e.s.t.i.n.g. .p.u.r.p.o.s.e...
.
.
Il metodo IO.readlines
La classe File è una sottoclasse della classe IO. La classe IO ha anche alcuni metodi che possono essere usati per manipolare i file.
Uno dei metodi della classe IO è IO.readlines . Questo metodo restituisce il contenuto del file riga per riga. Il codice seguente mostra l'utilizzo del metodo IO.readlines -
#!/usr/bin/ruby
arr = IO.readlines("input.txt")
puts arr[0]
puts arr[1]
In questo codice, la variabile arr è un array. Ogni riga del file input.txt sarà un elemento nell'array arr. Pertanto, arr [0] conterrà la prima riga, mentre arr [1] conterrà la seconda riga del file.
Il metodo IO.foreach
Questo metodo restituisce anche l'output riga per riga. La differenza tra il metodo foreach e il metodo readlines è che il metodo foreach è associato a un blocco. Tuttavia, a differenza del metodo readlines , il metodo foreach non restituisce un array. Ad esempio:
#!/usr/bin/ruby
IO.foreach("input.txt"){|block| puts block}
Questo codice passerà il contenuto del file test riga per riga al blocco variabile, quindi l'output verrà visualizzato sullo schermo.
Ridenominazione ed eliminazione di file
Puoi rinominare ed eliminare i file a livello di codice con Ruby con i metodi rename ed delete .
Di seguito è riportato l'esempio per rinominare un file esistente test1.txt -
#!/usr/bin/ruby
# Rename a file from test1.txt to test2.txt
File.rename( "test1.txt", "test2.txt" )
Di seguito è riportato l'esempio per eliminare un file esistente test2.txt -
#!/usr/bin/ruby
# Delete file test2.txt
File.delete("test2.txt")
Modalità e proprietà dei file
Usa il metodo chmod con una maschera per cambiare la modalità o le autorizzazioni / l'elenco di accesso di un file -
Di seguito è riportato l'esempio per modificare la modalità di un file esistente test.txt in un valore di maschera:
#!/usr/bin/ruby
file = File.new( "test.txt", "w" )
file.chmod( 0755 )
Sr.No. | Maschera e descrizione |
---|---|
1 | 0700 maschera rwx per il proprietario |
2 | 0400 r per proprietario |
3 | 0200 w per proprietario |
4 | 0100 x per proprietario |
5 | 0070 maschera rwx per gruppo |
6 | 0040 r per gruppo |
7 | 0020 w per gruppo |
8 | 0010 x per gruppo |
9 | 0007 maschera rwx per altri |
10 | 0004 r per altro |
11 | 0002 w per altro |
12 | 0001 x per altro |
13 | 4000 Imposta l'ID utente durante l'esecuzione |
14 | 2000 Imposta l'ID del gruppo durante l'esecuzione |
15 | 1000 Salva il testo scambiato, anche dopo l'uso |
Richieste di file
Il comando seguente verifica se un file esiste prima di aprirlo:
#!/usr/bin/ruby
File.open("file.rb") if File::exists?( "file.rb" )
Il seguente comando chiede se il file è davvero un file:
#!/usr/bin/ruby
# This returns either true or false
File.file?( "text.txt" )
Il seguente comando rileva se il nome file specificato è una directory:
#!/usr/bin/ruby
# a directory
File::directory?( "/usr/local/bin" ) # => true
# a file
File::directory?( "file.rb" ) # => false
Il comando seguente rileva se il file è leggibile, scrivibile o eseguibile:
#!/usr/bin/ruby
File.readable?( "test.txt" ) # => true
File.writable?( "test.txt" ) # => true
File.executable?( "test.txt" ) # => false
Il comando seguente rileva se il file ha dimensione zero o meno:
#!/usr/bin/ruby
File.zero?( "test.txt" ) # => true
Il comando seguente restituisce la dimensione del file:
#!/usr/bin/ruby
File.size?( "text.txt" ) # => 1002
Il seguente comando può essere utilizzato per scoprire un tipo di file:
#!/usr/bin/ruby
File::ftype( "test.txt" ) # => file
Il metodo ftype identifica il tipo di file restituendo uno dei seguenti: file, directory, characterSpecial, blockSpecial, fifo, link, socket o unknown.
Il seguente comando può essere utilizzato per trovare quando un file è stato creato, modificato o l'ultimo accesso:
#!/usr/bin/ruby
File::ctime( "test.txt" ) # => Fri May 09 10:06:37 -0700 2008
File::mtime( "text.txt" ) # => Fri May 09 10:44:44 -0700 2008
File::atime( "text.txt" ) # => Fri May 09 10:45:01 -0700 2008
Directory in Ruby
Tutti i file sono contenuti in varie directory e Ruby non ha problemi a gestirli. Mentre la classe File gestisce i file, le directory vengono gestite con la classe Dir .
Navigazione tra le directory
Per cambiare directory all'interno di un programma Ruby, utilizzare Dir.chdir come segue. Questo esempio cambia la directory corrente in / usr / bin .
Dir.chdir("/usr/bin")
Puoi scoprire qual è la directory corrente con Dir.pwd -
puts Dir.pwd # This will return something like /usr/bin
È possibile ottenere un elenco dei file e delle directory all'interno di una directory specifica utilizzando Dir.entries -
puts Dir.entries("/usr/bin").join(' ')
Dir.entries restituisce un array con tutte le voci all'interno della directory specificata. Dir. Foreach fornisce la stessa funzionalità:
Dir.foreach("/usr/bin") do |entry|
puts entry
end
Un modo ancora più conciso per ottenere elenchi di directory è usare il metodo dell'array di classi di Dir -
Dir["/usr/bin/*"]
Creazione di una directory
Il Dir.mkdir può essere utilizzato per creare le directory -
Dir.mkdir("mynewdir")
Puoi anche impostare i permessi su una nuova directory (non quella già esistente) con mkdir -
NOTE - La maschera 755 imposta i permessi proprietario, gruppo, mondo [chiunque] su rwxr-xr-x dove r = lettura, w = scrittura e x = esecuzione.
Dir.mkdir( "mynewdir", 755 )
Eliminazione di una directory
Il Dir.delete può essere utilizzato per eliminare una directory. I Dir.unlink e Dir.rmdir esegue esattamente la stessa funzione e sono forniti per comodità.
Dir.delete("testdir")
Creazione di file e directory temporanee
I file temporanei sono quelli che potrebbero essere creati brevemente durante l'esecuzione di un programma ma non sono un archivio permanente di informazioni.
Dir.tmpdir fornisce il percorso della directory temporanea sul sistema corrente, sebbene il metodo non sia disponibile per impostazione predefinita. Per rendere disponibile Dir.tmpdir è necessario utilizzare require 'tmpdir'.
È possibile utilizzare Dir.tmpdir con File.join per creare un file temporaneo indipendente dalla piattaforma -
require 'tmpdir'
tempfilename = File.join(Dir.tmpdir, "tingtong")
tempfile = File.new(tempfilename, "w")
tempfile.puts "This is a temporary file"
tempfile.close
File.delete(tempfilename)
Questo codice crea un file temporaneo, vi scrive i dati e lo elimina. La libreria standard di Ruby include anche una libreria chiamata Tempfile che può creare file temporanei per te -
require 'tempfile'
f = Tempfile.new('tingtong')
f.puts "Hello"
puts f.path
f.close
Funzioni integrate
Ecco le funzioni integrate di ruby per elaborare file e directory:
Classe di file e metodi .
Classe e metodi Dir .
L'esecuzione e l'eccezione vanno sempre insieme. Se stai aprendo un file, che non esiste, se non hai gestito correttamente questa situazione, il tuo programma è considerato di cattiva qualità.
Il programma si interrompe se si verifica un'eccezione. Quindi le eccezioni vengono utilizzate per gestire vari tipi di errori, che possono verificarsi durante l'esecuzione di un programma e intraprendere l'azione appropriata invece di interrompere completamente il programma.
Ruby fornisce un bel meccanismo per gestire le eccezioni. Racchiudiamo il codice che potrebbe sollevare un'eccezione in un blocco di inizio / fine e usiamo clausole di salvataggio per dire a Ruby i tipi di eccezioni che vogliamo gestire.
Sintassi
begin
# -
rescue OneTypeOfException
# -
rescue AnotherTypeOfException
# -
else
# Other exceptions
ensure
# Always will be executed
end
Tutto, dall'inizio al salvataggio, è protetto. Se si verifica un'eccezione durante l'esecuzione di questo blocco di codice, il controllo viene passato al blocco tra rescue e end .
Per ogni salvataggio clausola nel cominciare blocco, Ruby confronta l'Eccezione sollevata contro ciascuno dei parametri a loro volta. La corrispondenza avrà esito positivo se l'eccezione denominata nella clausola di salvataggio è la stessa del tipo dell'eccezione attualmente generata o è una superclasse di tale eccezione.
Nel caso in cui un'eccezione non corrisponda a nessuno dei tipi di errore specificati, ci è consentito utilizzare una clausola else dopo tutte le clausole di salvataggio .
Esempio
#!/usr/bin/ruby
begin
file = open("/unexistant_file")
if file
puts "File opened successfully"
end
rescue
file = STDIN
end
print file, "==", STDIN, "\n"
Questo produrrà il seguente risultato. Puoi vedere che STDIN è stato sostituito al file perché l' apertura non è riuscita.
#<IO:0xb7d16f84>==#<IO:0xb7d16f84>
Utilizzo dell'istruzione retry
È possibile catturare un'eccezione utilizzando salvataggio del blocco e quindi l'uso di tentativi istruzione da eseguire iniziare blocco fin dall'inizio.
Sintassi
begin
# Exceptions raised by this code will
# be caught by the following rescue clause
rescue
# This block will capture all types of exceptions
retry # This will move control to the beginning of begin
end
Esempio
#!/usr/bin/ruby
begin
file = open("/unexistant_file")
if file
puts "File opened successfully"
end
rescue
fname = "existant_file"
retry
end
Quello che segue è il flusso del processo:
- Si è verificata un'eccezione all'apertura.
- Sono andato a salvare. fname è stato riassegnato.
- Riprovando è andato all'inizio dell'inizio.
- Questo file ora si apre correttamente.
- Ha continuato il processo essenziale.
NOTE- Notare che se il file di nome ricostituito non esiste, questo codice di esempio riprova all'infinito. Fai attenzione se utilizzi Riprova per un processo di eccezione.
Utilizzo dell'istruzione raise
È possibile utilizzare rilancio dichiarazione per sollevare un'eccezione. Il metodo seguente solleva un'eccezione ogni volta che viene chiamato. Il secondo messaggio verrà stampato.
Sintassi
raise
OR
raise "Error Message"
OR
raise ExceptionType, "Error Message"
OR
raise ExceptionType, "Error Message" condition
La prima forma solleva semplicemente nuovamente l'eccezione corrente (o un RuntimeError se non ci sono eccezioni correnti). Viene utilizzato nei gestori di eccezioni che devono intercettare un'eccezione prima di trasmetterla.
La seconda forma crea una nuova eccezione RuntimeError , impostando il suo messaggio sulla stringa data. Questa eccezione viene quindi sollevata nello stack di chiamate.
La terza forma utilizza il primo argomento per creare un'eccezione e quindi imposta il messaggio associato al secondo argomento.
La quarta forma è simile alla terza ma puoi aggiungere qualsiasi istruzione condizionale come a meno che per sollevare un'eccezione.
Esempio
#!/usr/bin/ruby
begin
puts 'I am before the raise.'
raise 'An error has occurred.'
puts 'I am after the raise.'
rescue
puts 'I am rescued.'
end
puts 'I am after the begin block.'
Questo produrrà il seguente risultato:
I am before the raise.
I am rescued.
I am after the begin block.
Un altro esempio che mostra l'uso del rilancio -
#!/usr/bin/ruby
begin
raise 'A test exception.'
rescue Exception => e
puts e.message
puts e.backtrace.inspect
end
Questo produrrà il seguente risultato:
A test exception.
["main.rb:4"]
Utilizzando la dichiarazione di sicurezza
A volte, è necessario garantire che alcune elaborazioni vengano eseguite alla fine di un blocco di codice, indipendentemente dal fatto che sia stata sollevata un'eccezione. Ad esempio, potresti avere un file aperto all'ingresso del blocco e devi assicurarti che venga chiuso quando il blocco esce.
La clausola di garanzia fa proprio questo. garantire va dopo l'ultima clausola di salvataggio e contiene una porzione di codice che verrà sempre eseguita al termine del blocco. Non importa se il blocco esce normalmente, se solleva e salva un'eccezione o se viene terminato da un'eccezione non rilevata, il blocco di sicurezza verrà eseguito.
Sintassi
begin
#.. process
#..raise exception
rescue
#.. handle error
ensure
#.. finally ensure execution
#.. This will always execute.
end
Esempio
begin
raise 'A test exception.'
rescue Exception => e
puts e.message
puts e.backtrace.inspect
ensure
puts "Ensuring execution"
end
Questo produrrà il seguente risultato:
A test exception.
["main.rb:4"]
Ensuring execution
Utilizzo dell'istruzione else
Se la clausola else è presente, va dopo le clausole di salvataggio e prima di qualsiasi garanzia .
Il corpo di una clausola else viene eseguito solo se non vengono sollevate eccezioni dal corpo principale del codice.
Sintassi
begin
#.. process
#..raise exception
rescue
# .. handle error
else
#.. executes if there is no exception
ensure
#.. finally ensure execution
#.. This will always execute.
end
Esempio
begin
# raise 'A test exception.'
puts "I'm not raising exception"
rescue Exception => e
puts e.message
puts e.backtrace.inspect
else
puts "Congratulations-- no errors!"
ensure
puts "Ensuring execution"
end
Questo produrrà il seguente risultato:
I'm not raising exception
Congratulations-- no errors!
Ensuring execution
Il messaggio di errore generato può essere catturato usando $! variabile.
Prendi e lancia
Mentre il meccanismo di eccezione di rilancio e salvataggio è ottimo per abbandonare l'esecuzione quando le cose vanno male, a volte è bello essere in grado di saltare fuori da qualche costrutto profondamente annidato durante la normale elaborazione. Qui è dove prendere e lanciare torna utile.
Il fermo definisce un blocco che è etichettato con il nome dato (che può essere un simbolo o una stringa). Il blocco viene eseguito normalmente fino a quando non si incontra un lancio.
Sintassi
throw :lablename
#.. this will not be executed
catch :lablename do
#.. matching catch will be executed after a throw is encountered.
end
OR
throw :lablename condition
#.. this will not be executed
catch :lablename do
#.. matching catch will be executed after a throw is encountered.
end
Esempio
L'esempio seguente utilizza un lancio per terminare l'interazione con l'utente se "!" viene digitato in risposta a qualsiasi richiesta.
def promptAndGet(prompt)
print prompt
res = readline.chomp
throw :quitRequested if res == "!"
return res
end
catch :quitRequested do
name = promptAndGet("Name: ")
age = promptAndGet("Age: ")
sex = promptAndGet("Sex: ")
# ..
# process information
end
promptAndGet("Name:")
Dovresti provare il programma sopra sulla tua macchina perché necessita di interazione manuale. Questo produrrà il seguente risultato:
Name: Ruby on Rails
Age: 3
Sex: !
Name:Just Ruby
Eccezione di classe
Le classi ei moduli standard di Ruby sollevano eccezioni. Tutte le classi di eccezione formano una gerarchia, con la classe Eccezione in alto. Il livello successivo contiene sette diversi tipi:
- Interrupt
- NoMemoryError
- SignalException
- ScriptError
- StandardError
- SystemExit
C'è un'altra eccezione a questo livello, Fatal, ma l'interprete Ruby lo utilizza solo internamente.
Sia ScriptError che StandardError hanno un numero di sottoclassi, ma non è necessario entrare nei dettagli qui. La cosa importante è che se creiamo le nostre classi di eccezione, devono essere sottoclassi della classe Exception o di uno dei suoi discendenti.
Diamo un'occhiata a un esempio:
class FileSaveError < StandardError
attr_reader :reason
def initialize(reason)
@reason = reason
end
end
Ora, guarda il seguente esempio, che utilizzerà questa eccezione:
File.open(path, "w") do |file|
begin
# Write out the data ...
rescue
# Something went wrong!
raise FileSaveError.new($!)
end
end
La riga importante qui è raise FileSaveError.new ($!) . Chiamiamo raise per segnalare che si è verificata un'eccezione, passandogli una nuova istanza di FileSaveError, con il motivo che l'eccezione specifica ha causato il fallimento della scrittura dei dati.
Ruby è un puro linguaggio orientato agli oggetti e tutto appare a Ruby come un oggetto. Ogni valore in Ruby è un oggetto, anche le cose più primitive: stringhe, numeri e anche vero e falso. Anche una classe stessa è un oggetto che è un'istanza della classe Class . Questo capitolo ti guiderà attraverso tutte le principali funzionalità relative a Object Oriented Ruby.
Una classe viene utilizzata per specificare la forma di un oggetto e combina la rappresentazione dei dati e i metodi per manipolare tali dati in un unico pacchetto pulito. I dati e i metodi all'interno di una classe sono chiamati membri della classe.
Ruby Class Definition
Quando si definisce una classe, si definisce un progetto per un tipo di dati. Questo in realtà non definisce alcun dato, ma definisce cosa significa il nome della classe, cioè, di cosa sarà composto un oggetto della classe e quali operazioni possono essere eseguite su tale oggetto.
Una definizione di classe inizia con la parola chiave class seguito dal class name ed è delimitato da un end. Ad esempio, abbiamo definito la classe Box utilizzando la classe di parole chiave come segue:
class Box
code
end
Il nome deve iniziare con una lettera maiuscola e per convenzione i nomi che contengono più di una parola vengono eseguiti insieme a ciascuna parola in maiuscolo e senza caratteri di separazione (CamelCase).
Definisci oggetti Ruby
Una classe fornisce i progetti per gli oggetti, quindi fondamentalmente un oggetto viene creato da una classe. Dichiariamo gli oggetti di una classe usandonewparola chiave. Le seguenti istruzioni dichiarano due oggetti della classe Box -
box1 = Box.new
box2 = Box.new
Il metodo di inizializzazione
Il initialize method è un metodo di classe Ruby standard e funziona quasi allo stesso modo di constructorfunziona in altri linguaggi di programmazione orientati agli oggetti. Il metodo initialize è utile quando si desidera inizializzare alcune variabili di classe al momento della creazione dell'oggetto. Questo metodo potrebbe richiedere un elenco di parametri e come qualsiasi altro metodo ruby sarebbe preceduto dadef parola chiave come mostrato di seguito -
class Box
def initialize(w,h)
@width, @height = w, h
end
end
Le variabili di istanza
Il instance variablessono una specie di attributi di classe e diventano proprietà degli oggetti una volta che gli oggetti vengono creati utilizzando la classe. Gli attributi di ogni oggetto vengono assegnati individualmente e non condividono alcun valore con altri oggetti. Sono accessibili utilizzando l'operatore @ all'interno della classe ma per accedervi al di fuori della classe che usiamopublic metodi, che vengono chiamati accessor methods. Se prendiamo la classe sopra definitaBox quindi @width e @height sono variabili di istanza per la classe Box.
class Box
def initialize(w,h)
# assign instance variables
@width, @height = w, h
end
end
I metodi di accesso e setter
Per rendere disponibili le variabili dall'esterno della classe, è necessario definirle all'interno accessor methods, questi metodi di accesso sono noti anche come metodi getter. L'esempio seguente mostra l'utilizzo dei metodi di accesso:
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# accessor methods
def printWidth
@width
end
def printHeight
@height
end
end
# create an object
box = Box.new(10, 20)
# use accessor methods
x = box.printWidth()
y = box.printHeight()
puts "Width of the box is : #{x}"
puts "Height of the box is : #{y}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
Width of the box is : 10
Height of the box is : 20
Simile ai metodi di accesso, che vengono utilizzati per accedere al valore delle variabili, Ruby fornisce un modo per impostare i valori di tali variabili dall'esterno della classe utilizzando setter methods, che sono definiti come di seguito -
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# accessor methods
def getWidth
@width
end
def getHeight
@height
end
# setter methods
def setWidth=(value)
@width = value
end
def setHeight=(value)
@height = value
end
end
# create an object
box = Box.new(10, 20)
# use setter methods
box.setWidth = 30
box.setHeight = 50
# use accessor methods
x = box.getWidth()
y = box.getHeight()
puts "Width of the box is : #{x}"
puts "Height of the box is : #{y}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
Width of the box is : 30
Height of the box is : 50
I metodi di istanza
Il instance methods sono anche definiti nello stesso modo in cui definiamo qualsiasi altro metodo utilizzando defparola chiave e possono essere utilizzati utilizzando un'istanza di classe solo come mostrato di seguito. La loro funzionalità non si limita all'accesso alle variabili di istanza, ma possono anche fare molto di più secondo le tue esigenze.
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# instance method
def getArea
@width * @height
end
end
# create an object
box = Box.new(10, 20)
# call instance methods
a = box.getArea()
puts "Area of the box is : #{a}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
Area of the box is : 200
I metodi e le variabili della classe
Il class variablesè una variabile condivisa tra tutte le istanze di una classe. In altre parole, esiste un'istanza della variabile a cui si accede dalle istanze dell'oggetto. Le variabili di classe sono precedute da due caratteri @ (@@). Una variabile di classe deve essere inizializzata all'interno della definizione di classe come mostrato di seguito.
Un metodo di classe viene definito utilizzando def self.methodname(), che termina con il delimitatore di fine e verrebbe chiamato utilizzando il nome della classe come classname.methodname come mostrato nell'esempio seguente:
#!/usr/bin/ruby -w
class Box
# Initialize our class variables
@@count = 0
def initialize(w,h)
# assign instance avriables
@width, @height = w, h
@@count += 1
end
def self.printCount()
puts "Box count is : #@@count"
end
end
# create two object
box1 = Box.new(10, 20)
box2 = Box.new(30, 100)
# call class method to print box count
Box.printCount()
Quando il codice precedente viene eseguito, produce il seguente risultato:
Box count is : 2
Il metodo to_s
Qualsiasi classe definita dovrebbe avere un'estensione to_smetodo di istanza per restituire una rappresentazione di stringa dell'oggetto. Di seguito è riportato un semplice esempio per rappresentare un oggetto Box in termini di larghezza e altezza:
#!/usr/bin/ruby -w
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# define to_s method
def to_s
"(w:#@width,h:#@height)" # string formatting of the object.
end
end
# create an object
box = Box.new(10, 20)
# to_s method will be called in reference of string automatically.
puts "String representation of box is : #{box}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
String representation of box is : (w:10,h:20)
Controllo di accesso
Ruby ti offre tre livelli di protezione a livello di metodi di istanza, che possono essere public, private, or protected. Ruby non applica alcun controllo di accesso sulle variabili di istanza e di classe.
Public Methods- I metodi pubblici possono essere chiamati da chiunque. I metodi sono pubblici per impostazione predefinita ad eccezione di initialize, che è sempre privato.
Private Methods- Non è possibile accedere ai metodi privati o addirittura visualizzarli dall'esterno della classe. Solo i metodi della classe possono accedere ai membri privati.
Protected Methods- Un metodo protetto può essere invocato solo dagli oggetti della classe che lo definisce e dalle sue sottoclassi. L'accesso è mantenuto all'interno della famiglia.
Di seguito è riportato un semplice esempio per mostrare la sintassi di tutti e tre i modificatori di accesso:
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# instance method by default it is public
def getArea
getWidth() * getHeight
end
# define private accessor methods
def getWidth
@width
end
def getHeight
@height
end
# make them private
private :getWidth, :getHeight
# instance method to print area
def printArea
@area = getWidth() * getHeight
puts "Big box area is : #@area"
end
# make it protected
protected :printArea
end
# create an object
box = Box.new(10, 20)
# call instance methods
a = box.getArea()
puts "Area of the box is : #{a}"
# try to call protected or methods
box.printArea()
Quando il codice precedente viene eseguito, produce il seguente risultato. Qui, il primo metodo viene chiamato con successo ma il secondo metodo ha dato un problema.
Area of the box is : 200
test.rb:42: protected method `printArea' called for #
<Box:0xb7f11280 @height = 20, @width = 10> (NoMethodError)
Ereditarietà di classe
Uno dei concetti più importanti nella programmazione orientata agli oggetti è quello dell'ereditarietà. L'ereditarietà ci consente di definire una classe in termini di un'altra classe, il che semplifica la creazione e la manutenzione di un'applicazione.
L'ereditarietà offre anche l'opportunità di riutilizzare la funzionalità del codice e tempi di implementazione rapidi ma sfortunatamente Ruby non supporta più livelli di ereditarietà ma Ruby supporta mixins. Un mixin è come un'implementazione specializzata di ereditarietà multipla in cui viene ereditata solo la parte dell'interfaccia.
Quando si crea una classe, invece di scrivere membri dati e funzioni membro completamente nuovi, il programmatore può designare che la nuova classe erediti i membri di una classe esistente. Questa classe esistente è chiamatabase class or superclasse la nuova classe è denominata derived class or sub-class.
Ruby supporta anche il concetto di sottoclasse, cioè ereditarietà e il seguente esempio spiega il concetto. La sintassi per estendere una classe è semplice. Basta aggiungere un carattere <e il nome della superclasse alla dichiarazione della classe. Ad esempio, di seguito definire una classe BigBox come una sottoclasse di Box -
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# instance method
def getArea
@width * @height
end
end
# define a subclass
class BigBox < Box
# add a new instance method
def printArea
@area = @width * @height
puts "Big box area is : #@area"
end
end
# create an object
box = BigBox.new(10, 20)
# print the area
box.printArea()
Quando il codice precedente viene eseguito, produce il seguente risultato:
Big box area is : 200
Metodi che sovrascrivono
Sebbene tu possa aggiungere nuove funzionalità in una classe derivata, ma a volte vorresti cambiare il comportamento di un metodo già definito in una classe genitore. Puoi farlo semplicemente mantenendo lo stesso nome del metodo e sovrascrivendo la funzionalità del metodo come mostrato di seguito nell'esempio:
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# instance method
def getArea
@width * @height
end
end
# define a subclass
class BigBox < Box
# change existing getArea method as follows
def getArea
@area = @width * @height
puts "Big box area is : #@area"
end
end
# create an object
box = BigBox.new(10, 20)
# print the area using overriden method.
box.getArea()
Sovraccarico dell'operatore
Vorremmo che l'operatore + eseguisse l'aggiunta vettoriale di due oggetti Box utilizzando +, l'operatore * per moltiplicare una larghezza e un'altezza di Box per uno scalare e l'operatore unario - per negare la larghezza e l'altezza del Box. Ecco una versione della classe Box con gli operatori matematici definiti:
class Box
def initialize(w,h) # Initialize the width and height
@width,@height = w, h
end
def +(other) # Define + to do vector addition
Box.new(@width + other.width, @height + other.height)
end
def -@ # Define unary minus to negate width and height
Box.new(-@width, -@height)
end
def *(scalar) # To perform scalar multiplication
Box.new(@width*scalar, @height*scalar)
end
end
Congelamento di oggetti
A volte, vogliamo impedire che un oggetto venga modificato. Il metodo freeze in Object ci permette di farlo, trasformando efficacemente un oggetto in una costante. Qualsiasi oggetto può essere congelato invocandoObject.freeze. Un oggetto congelato non può essere modificato: non puoi cambiare le sue variabili di istanza.
Puoi controllare se un determinato oggetto è già congelato o non lo utilizza Object.frozen?metodo, che restituisce true nel caso in cui l'oggetto sia congelato, altrimenti viene restituito un valore false. L'esempio seguente chiarisce il concetto:
#!/usr/bin/ruby -w
# define a class
class Box
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# accessor methods
def getWidth
@width
end
def getHeight
@height
end
# setter methods
def setWidth=(value)
@width = value
end
def setHeight=(value)
@height = value
end
end
# create an object
box = Box.new(10, 20)
# let us freez this object
box.freeze
if( box.frozen? )
puts "Box object is frozen object"
else
puts "Box object is normal object"
end
# now try using setter methods
box.setWidth = 30
box.setHeight = 50
# use accessor methods
x = box.getWidth()
y = box.getHeight()
puts "Width of the box is : #{x}"
puts "Height of the box is : #{y}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
Box object is frozen object
test.rb:20:in `setWidth=': can't modify frozen object (TypeError)
from test.rb:39
Costanti di classe
È possibile definire una costante all'interno di una classe assegnando un valore numerico o stringa diretto a una variabile, che viene definita senza utilizzare @ o @@. Per convenzione, manteniamo i nomi delle costanti in maiuscolo.
Una volta definita una costante, non è possibile modificarne il valore ma è possibile accedere a una costante direttamente all'interno di una classe in modo molto simile a una variabile, ma se si desidera accedere a una costante al di fuori della classe, è necessario utilizzare classname::constant come mostrato nell'esempio seguente.
#!/usr/bin/ruby -w
# define a class
class Box
BOX_COMPANY = "TATA Inc"
BOXWEIGHT = 10
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# instance method
def getArea
@width * @height
end
end
# create an object
box = Box.new(10, 20)
# call instance methods
a = box.getArea()
puts "Area of the box is : #{a}"
puts Box::BOX_COMPANY
puts "Box weight is: #{Box::BOXWEIGHT}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
Area of the box is : 200
TATA Inc
Box weight is: 10
Le costanti di classe vengono ereditate e possono essere sovrascritte come i metodi di istanza.
Crea oggetto usando Alloca
Potrebbe esserci una situazione in cui si desidera creare un oggetto senza chiamare il suo costruttore initializecioè usando un nuovo metodo, in tal caso puoi chiamare allocate , che creerà un oggetto non inizializzato per te come nell'esempio seguente -
#!/usr/bin/ruby -w
# define a class
class Box
attr_accessor :width, :height
# constructor method
def initialize(w,h)
@width, @height = w, h
end
# instance method
def getArea
@width * @height
end
end
# create an object using new
box1 = Box.new(10, 20)
# create another object using allocate
box2 = Box.allocate
# call instance method using box1
a = box1.getArea()
puts "Area of the box is : #{a}"
# call instance method using box2
a = box2.getArea()
puts "Area of the box is : #{a}"
Quando il codice precedente viene eseguito, produce il seguente risultato:
Area of the box is : 200
test.rb:14: warning: instance variable @width not initialized
test.rb:14: warning: instance variable @height not initialized
test.rb:14:in `getArea': undefined method `*'
for nil:NilClass (NoMethodError) from test.rb:29
Informazioni sulla classe
Se le definizioni di classe sono codice eseguibile, ciò implica che vengano eseguite nel contesto di un oggetto: self deve fare riferimento a qualcosa. Scopriamo cos'è.
#!/usr/bin/ruby -w
class Box
# print class information
puts "Type of self = #{self.type}"
puts "Name of self = #{self.name}"
end
Quando il codice precedente viene eseguito, produce il seguente risultato:
Type of self = Class
Name of self = Box
Ciò significa che una definizione di classe viene eseguita con quella classe come oggetto corrente. Ciò significa che i metodi nella metaclasse e nelle sue superclassi saranno disponibili durante l'esecuzione della definizione del metodo.
Un'espressione regolare è una sequenza di caratteri speciale che consente di abbinare o trovare altre stringhe o insiemi di stringhe utilizzando una sintassi specializzata, impartita in un modello.
Un letterale di espressione regolare è un modello tra barre o tra delimitatori arbitrari seguito da% r come segue:
Sintassi
/pattern/
/pattern/im # option can be specified
%r!/usr/local! # general delimited regular expression
Esempio
#!/usr/bin/ruby
line1 = "Cats are smarter than dogs";
line2 = "Dogs also like meat";
if ( line1 =~ /Cats(.*)/ )
puts "Line1 contains Cats"
end
if ( line2 =~ /Cats(.*)/ )
puts "Line2 contains Dogs"
end
Questo produrrà il seguente risultato:
Line1 contains Cats
Modificatori di espressioni regolari
I letterali delle espressioni regolari possono includere un modificatore opzionale per controllare vari aspetti della corrispondenza. Il modificatore è specificato dopo il secondo carattere barra, come mostrato in precedenza e può essere rappresentato da uno di questi caratteri -
Sr.No. | Modificatore e descrizione |
---|---|
1 | i Ignora maiuscole e minuscole durante la corrispondenza del testo. |
2 | o Esegue # {} interpolazioni solo una volta, la prima volta che viene valutato il valore letterale regexp. |
3 | x Ignora gli spazi e consente i commenti nelle espressioni regolari. |
4 | m Corrisponde a più righe, riconoscendo le nuove righe come caratteri normali. |
5 | u,e,s,n Interpreta la regexp come Unicode (UTF-8), EUC, SJIS o ASCII. Se nessuno di questi modificatori viene specificato, si presume che l'espressione regolare utilizzi la codifica sorgente. |
Come le stringhe letterali delimitate con% Q, Ruby ti permette di iniziare le tue espressioni regolari con% r seguito da un delimitatore a tua scelta. Questo è utile quando il pattern che stai descrivendo contiene molti caratteri barra in avanti che non vuoi sfuggire -
# Following matches a single slash character, no escape required
%r|/|
# Flag characters are allowed with this syntax, too
%r[</(.*)>]i
Modelli di espressioni regolari
Fatta eccezione per i personaggi di controllo, (+ ? . * ^ $ ( ) [ ] { } | \), tutti i personaggi corrispondono a se stessi. È possibile eseguire l'escape di un carattere di controllo precedendolo con una barra rovesciata.
Sr.No. | Modello e descrizione |
---|---|
1 | ^ Corrisponde all'inizio della riga. |
2 | $ Corrisponde alla fine della riga. |
3 | . Corrisponde a qualsiasi carattere singolo tranne la nuova riga. L'uso dell'opzione m consente anche di abbinare la nuova riga. |
4 | [...] Corrisponde a qualsiasi singolo carattere tra parentesi. |
5 | [^...] Corrisponde a qualsiasi carattere singolo non tra parentesi |
6 | re* Corrisponde a 0 o più occorrenze dell'espressione precedente. |
7 | re+ Corrisponde a 1 o più occorrenze dell'espressione precedente. |
8 | re? Corrisponde a 0 o 1 occorrenza dell'espressione precedente. |
9 | re{ n} Corrisponde esattamente al numero n di occorrenze dell'espressione precedente. |
10 | re{ n,} Corrisponde a n o più occorrenze dell'espressione precedente. |
11 | re{ n, m} Corrisponde ad almeno n e al massimo m occorrenze dell'espressione precedente. |
12 | a| b Corrisponde a a o b. |
13 | (re) Raggruppa le espressioni regolari e ricorda il testo corrispondente. |
14 | (?imx) Attiva temporaneamente le opzioni i, m o x all'interno di un'espressione regolare. Se tra parentesi, viene interessata solo quell'area. |
15 | (?-imx) Disattiva temporaneamente le opzioni i, m o x all'interno di un'espressione regolare. Se tra parentesi, viene interessata solo quell'area. |
16 | (?: re) Raggruppa le espressioni regolari senza ricordare il testo corrispondente. |
17 | (?imx: re) Attiva temporaneamente le opzioni i, m o x tra parentesi. |
18 | (?-imx: re) Disattiva temporaneamente le opzioni i, m o x tra parentesi. |
19 | (?#...) Commento. |
20 | (?= re) Specifica la posizione utilizzando un modello. Non ha una gamma. |
21 | (?! re) Specifica la posizione utilizzando la negazione del modello. Non ha una gamma. |
22 | (?> re) Corrisponde a pattern indipendenti senza backtracking. |
23 | \w Corrisponde ai caratteri delle parole. |
24 | \W Corrisponde a caratteri non di parole. |
25 | \s Corrisponde allo spazio bianco. Equivalente a [\ t \ n \ r \ f]. |
26 | \S Corrisponde a spazi non bianchi. |
27 | \d Corrisponde alle cifre. Equivalente a [0-9]. |
28 | \D Corrisponde a non cifre. |
29 | \A Corrisponde all'inizio della stringa. |
30 | \Z Corrisponde alla fine della stringa. Se esiste una nuova riga, corrisponde appena prima della nuova riga. |
31 | \z Corrisponde alla fine della stringa. |
32 | \G Punto delle partite in cui è finita l'ultima partita. |
33 | \b Corrisponde ai confini delle parole quando fuori dalle parentesi. Corrisponde a backspace (0x08) quando è racchiuso tra parentesi. |
34 | \B Corrisponde ai confini non di parole. |
35 | \n, \t, etc. Trova nuove righe, ritorni a capo, tabulazioni, ecc. |
36 | \1...\9 Corrisponde all'ennesima sottoespressione raggruppata. |
37 | \10 Corrisponde all'ennesima sottoespressione raggruppata se corrisponde già. Altrimenti si riferisce alla rappresentazione ottale di un codice carattere. |
Esempi di espressioni regolari
Sr.No. | Esempio e descrizione |
---|---|
1 | /ruby/ Corrisponde a "ruby". |
2 | ¥ Corrisponde al segno di Yen. I caratteri multibyte sono supportati in Ruby 1.9 e Ruby 1.8. |
Sr.No. | Esempio e descrizione |
---|---|
1 | /[Rr]uby/ Corrisponde a "Ruby" o "ruby". |
2 | /rub[ye]/ Corrisponde a "ruby" o "rube". |
3 | /[aeiou]/ Corrisponde a una vocale qualsiasi minuscola. |
4 | /[0-9]/ Corrisponde a qualsiasi cifra; uguale a / [0123456789] /. |
5 | /[a-z]/ Corrisponde a qualsiasi lettera ASCII minuscola. |
6 | /[A-Z]/ Corrisponde a qualsiasi lettera ASCII maiuscola. |
7 | /[a-zA-Z0-9]/ Corrisponde a uno dei precedenti. |
8 | /[^aeiou]/ Corrisponde a qualsiasi cosa diversa da una vocale minuscola. |
9 | /[^0-9]/ Corrisponde a qualsiasi cosa diversa da una cifra. |
Sr.No. | Esempio e descrizione |
---|---|
1 | /./ Corrisponde a qualsiasi carattere tranne la nuova riga. |
2 | /./m In modalità multilinea, corrisponde anche alla nuova riga. |
3 | /\d/ Corrisponde a una cifra: / [0-9] /. |
4 | /\D/ Corrisponde a una non cifra: / [^ 0-9] /. |
5 | /\s/ Corrisponde a uno spazio vuoto: / [\ t \ r \ n \ f] /. |
6 | /\S/ Corrisponde a spazi diversi da spazi: / [^ \ t \ r \ n \ f] /. |
7 | /\w/ Corrisponde a un carattere di una sola parola: / [A-Za-z0-9 _] /. |
8 | /\W/ Corrisponde a un carattere non alfanumerico: / [^ A-Za-z0-9 _] /. |
Sr.No. | Esempio e descrizione |
---|---|
1 | /ruby?/ Corrisponde a "rub" o "ruby": la y è facoltativa. |
2 | /ruby*/ Corrisponde a "strofinare" più 0 o più anni. |
3 | /ruby+/ Corrisponde a "strofinare" più 1 o più anni. |
4 | /\d{3}/ Corrisponde esattamente a 3 cifre. |
5 | /\d{3,}/ Corrisponde a 3 o più cifre. |
6 | /\d{3,5}/ Corrisponde a 3, 4 o 5 cifre. |
Corrisponde al minor numero di ripetizioni -
Sr.No. | Esempio e descrizione |
---|---|
1 | /<.*>/ Ripetizione avida: corrisponde a "<ruby> perl>". |
2 | /<.*?>/ Non avido: trova "<ruby>" in "<ruby> perl>". |
Sr.No. | Esempio e descrizione |
---|---|
1 | /\D\d+/ Nessun gruppo: + si ripete \ d |
2 | /(\D\d)+/ Raggruppato: + ripete la coppia \ D \ d |
3 | /([Rr]uby(, )?)+/ Abbina "Ruby", "Ruby, ruby, ruby" e così via. |
Questo corrisponde di nuovo a un gruppo precedentemente abbinato -
Sr.No. | Esempio e descrizione |
---|---|
1 | /([Rr])uby&\1ails/ Abbina Ruby & Rails o Ruby & Rails. |
2 | /(['"])(?:(?!\1).)*\1/ Stringa tra virgolette singole o doppie. \ 1 corrisponde a qualsiasi corrispondenza del primo gruppo. \ 2 corrisponde a qualunque sia il 2 ° gruppo abbinato, ecc. |
Sr.No. | Esempio e descrizione |
---|---|
1 | /ruby|rube/ Corrisponde a "ruby" o "rube". |
2 | /rub(y|le))/ Corrisponde a "rubino" o "rublo". |
3 | /ruby(!+|\?)/ "rubino" seguito da uno o più! o uno? |
Deve specificare la posizione della partita.
Sr.No. | Esempio e descrizione |
---|---|
1 | /^Ruby/ Trova "Ruby" all'inizio di una stringa o di una riga interna. |
2 | /Ruby$/ Corrisponde a "Ruby" alla fine di una stringa o di una riga. |
3 | /\ARuby/ Trova "Ruby" all'inizio di una stringa. |
4 | /Ruby\Z/ Corrisponde a "Ruby" alla fine di una stringa. |
5 | /\bRuby\b/ Corrisponde a "Ruby" in corrispondenza del confine di una parola. |
6 | /\brub\B/ \ B è un confine non di parola: corrisponde a "rub" in "rube" e "ruby" ma non da solo. |
7 | /Ruby(?=!)/ Corrisponde a "Ruby", se seguito da un punto esclamativo. |
8 | /Ruby(?!!)/ Corrisponde a "Ruby", se non seguito da un punto esclamativo. |
Sr.No. | Esempio e descrizione |
---|---|
1 | /R(?#comment)/ Corrisponde a "R". Tutto il resto è un commento. |
2 | /R(?i)uby/ Non distingue tra maiuscole e minuscole durante la corrispondenza di "uby". |
3 | /R(?i:uby)/ Come sopra. |
4 | /rub(?:y|le))/ Raggruppa solo senza creare \ 1 backreference. |
Cerca e sostituisci
Alcuni dei metodi String più importanti che utilizzano espressioni regolari sono sub e gsube le loro varianti sul posto sub! e gsub!.
Tutti questi metodi eseguono un'operazione di ricerca e sostituzione utilizzando un pattern Regexp. Ilsub & sub! sostituisce la prima occorrenza del modello e gsub & gsub! sostituisce tutte le occorrenze.
Il sub e gsub restituisce una nuova stringa, lasciando l'originale non modificato dove come sub! e gsub! modificare la stringa su cui vengono chiamati.
Di seguito è riportato l'esempio:
#!/usr/bin/ruby
phone = "2004-959-559 #This is Phone Number"
# Delete Ruby-style comments
phone = phone.sub!(/#.*$/, "")
puts "Phone Num : #{phone}"
# Remove anything other than digits
phone = phone.gsub!(/\D/, "")
puts "Phone Num : #{phone}"
Questo produrrà il seguente risultato:
Phone Num : 2004-959-559
Phone Num : 2004959559
Di seguito è riportato un altro esempio:
#!/usr/bin/ruby
text = "rails are rails, really good Ruby on Rails"
# Change "rails" to "Rails" throughout
text.gsub!("rails", "Rails")
# Capitalize the word "Rails" throughout
text.gsub!(/\brails\b/, "Rails")
puts "#{text}"
Questo produrrà il seguente risultato:
Rails are Rails, really good Ruby on Rails
Questo capitolo ti insegna come accedere a un database usando Ruby. Il modulo Ruby DBI fornisce un'interfaccia indipendente dal database per gli script Ruby simile a quella del modulo Perl DBI.
DBI sta per Database Independent Interface per Ruby, il che significa che DBI fornisce un livello di astrazione tra il codice Ruby e il database sottostante, consentendo di cambiare le implementazioni del database molto facilmente. Definisce un insieme di metodi, variabili e convenzioni che forniscono un'interfaccia database coerente, indipendentemente dal database effettivamente utilizzato.
DBI può interfacciarsi con quanto segue:
- ADO (ActiveX Data Objects)
- DB2
- Frontbase
- mSQL
- MySQL
- ODBC
- Oracle
- OCI8 (Oracle)
- PostgreSQL
- Proxy/Server
- SQLite
- SQLRelay
Architettura di un'applicazione DBI
DBI è indipendente da qualsiasi database disponibile nel backend. È possibile utilizzare DBI sia che si lavori con Oracle, MySQL o Informix, ecc. Questo è chiaro dal seguente diagramma dell'architettura.
L'architettura generale per Ruby DBI utilizza due livelli:
Il livello dell'interfaccia database (DBI). Questo livello è indipendente dal database e fornisce una serie di metodi di accesso comuni che vengono utilizzati allo stesso modo indipendentemente dal tipo di server di database con cui si sta comunicando.
Il livello del driver del database (DBD). Questo livello dipende dal database; driver diversi forniscono l'accesso a diversi motori di database. C'è un driver per MySQL, un altro per PostgreSQL, un altro per InterBase, un altro per Oracle e così via. Ogni driver interpreta le richieste dal livello DBI e le mappa su richieste appropriate per un dato tipo di server di database.
Prerequisiti
Se vuoi scrivere script Ruby per accedere ai database MySQL, devi avere installato il modulo Ruby MySQL.
Questo modulo funge da DBD come spiegato sopra e può essere scaricato da https://www.tmtm.org/en/mysql/ruby/
Ottenere e installare Ruby / DBI
È possibile scaricare e installare il modulo Ruby DBI dal seguente percorso:
https://imgur.com/NFEuWe4/embed
Prima di iniziare questa installazione assicurati di avere i privilegi di root. Ora, segui i passaggi indicati di seguito:
Passo 1
$ tar zxf dbi-0.2.0.tar.gz
Passo 2
Vai nella directory di distribuzione dbi-0.2.0 e configuralo usando lo script setup.rb in quella directory. Il comando di configurazione più generale è simile a questo, senza argomenti che seguono l'argomento config. Questo comando configura la distribuzione per installare tutti i driver per impostazione predefinita.
$ ruby setup.rb config
Per essere più precisi, fornisci un'opzione --with che elenca le parti particolari della distribuzione che desideri utilizzare. Ad esempio, per configurare solo il modulo DBI principale e il driver di livello DBD MySQL, emettere il seguente comando:
$ ruby setup.rb config --with = dbi,dbd_mysql
Passaggio 3
Il passaggio finale è creare il driver e installarlo utilizzando i seguenti comandi:
$ ruby setup.rb setup $ ruby setup.rb install
Connessione al database
Supponendo che lavoreremo con il database MySQL, prima di connetterci a un database assicurati di quanto segue:
Hai creato un database TESTDB.
Hai creato EMPLOYEE in TESTDB.
Questa tabella contiene i campi FIRST_NAME, LAST_NAME, AGE, SEX e INCOME.
L'ID utente "testuser" e la password "test123" sono impostati per accedere a TESTDB.
Ruby Module DBI è installato correttamente sulla tua macchina.
Hai seguito il tutorial di MySQL per comprendere le basi di MySQL.
Di seguito è riportato l'esempio di connessione con il database MySQL "TESTDB"
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
# get server version string and display it
row = dbh.select_one("SELECT VERSION()")
puts "Server version: " + row[0]
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
ensure
# disconnect from server
dbh.disconnect if dbh
end
Durante l'esecuzione di questo script, produce il seguente risultato sulla nostra macchina Linux.
Server version: 5.0.45
Se viene stabilita una connessione con l'origine dati, viene restituito un handle di database e salvato in dbh per un ulteriore utilizzo in caso contrario dbhè impostato su un valore nullo e e.err ed e :: errstr restituiscono rispettivamente il codice di errore e una stringa di errore.
Infine, prima di uscire, assicurati che la connessione al database sia chiusa e le risorse siano rilasciate.
Operazione INSERT
L'operazione INSERT è necessaria quando si desidera creare i record in una tabella di database.
Una volta stabilita una connessione al database, siamo pronti per creare tabelle o record nelle tabelle del database utilizzando do metodo o prepare e execute metodo.
Utilizzando do Statement
Le istruzioni che non restituiscono righe possono essere emesse richiamando il dometodo di gestione del database. Questo metodo accetta un argomento stringa di istruzione e restituisce un conteggio del numero di righe interessate dall'istruzione.
dbh.do("DROP TABLE IF EXISTS EMPLOYEE")
dbh.do("CREATE TABLE EMPLOYEE (
FIRST_NAME CHAR(20) NOT NULL,
LAST_NAME CHAR(20),
AGE INT,
SEX CHAR(1),
INCOME FLOAT )" );
Allo stesso modo, è possibile eseguire l' istruzione SQL INSERT per creare un record nella tabella EMPLOYEE.
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
dbh.do( "INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES ('Mac', 'Mohan', 20, 'M', 2000)" )
puts "Record has been created"
dbh.commit
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
Utilizzando prepara ed esegui
È possibile utilizzare i metodi di preparazione ed esecuzione della classe DBI per eseguire l'istruzione SQL tramite il codice Ruby.
La creazione di record richiede i seguenti passaggi:
Preparazione dell'istruzione SQL con l'istruzione INSERT. Questo sarà fatto usando ilprepare metodo.
Esecuzione di query SQL per selezionare tutti i risultati dal database. Questo sarà fatto usando ilexecute metodo.
Rilascio dell'handle di istruzione. Questo sarà fatto usandofinish API
Se tutto va bene, allora commit questa operazione altrimenti puoi rollback la transazione completa.
Di seguito è riportata la sintassi per utilizzare questi due metodi:
sth = dbh.prepare(statement)
sth.execute
... zero or more SQL operations ...
sth.finish
Questi due metodi possono essere utilizzati per passare bindvalori alle istruzioni SQL. Potrebbe esserci un caso in cui i valori da inserire non vengono forniti in anticipo. In tal caso, vengono utilizzati i valori di associazione. Un punto interrogativo (?) viene utilizzato al posto dei valori effettivi e quindi i valori effettivi vengono passati tramite l'API execute ().
Di seguito è riportato l'esempio per creare due record nella tabella EMPLOYEE -
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare( "INSERT INTO EMPLOYEE(FIRST_NAME, LAST_NAME, AGE, SEX, INCOME)
VALUES (?, ?, ?, ?, ?)" )
sth.execute('John', 'Poul', 25, 'M', 2300)
sth.execute('Zara', 'Ali', 17, 'F', 1000)
sth.finish
dbh.commit
puts "Record has been created"
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
Se sono presenti più INSERT alla volta, preparare prima un'istruzione e poi eseguirla più volte all'interno di un ciclo è più efficiente rispetto a invocare ogni volta attraverso il ciclo.
Operazione READ
READ Operare su qualsiasi database significa prelevare alcune informazioni utili dal database.
Una volta stabilita la connessione al database, siamo pronti per eseguire una query in questo database. Possiamo usare entrambido metodo o prepare e execute metodi per recuperare i valori da una tabella di database.
Il recupero dei record richiede i seguenti passaggi:
Preparazione di query SQL in base alle condizioni richieste. Questo sarà fatto usando ilprepare metodo.
Esecuzione di query SQL per selezionare tutti i risultati dal database. Questo sarà fatto usando ilexecute metodo.
Recuperare tutti i risultati uno per uno e stamparli. Questo sarà fatto usando ilfetch metodo.
Rilascio dell'handle di istruzione. Questo sarà fatto usando ilfinish metodo.
Di seguito è riportata la procedura per interrogare tutti i record dalla tabella DIPENDENTE con stipendio superiore a 1000.
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare("SELECT * FROM EMPLOYEE WHERE INCOME > ?")
sth.execute(1000)
sth.fetch do |row|
printf "First Name: %s, Last Name : %s\n", row[0], row[1]
printf "Age: %d, Sex : %s\n", row[2], row[3]
printf "Salary :%d \n\n", row[4]
end
sth.finish
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
ensure
# disconnect from server
dbh.disconnect if dbh
end
Questo produrrà il seguente risultato:
First Name: Mac, Last Name : Mohan
Age: 20, Sex : M
Salary :2000
First Name: John, Last Name : Poul
Age: 25, Sex : M
Salary :2300
Esistono più metodi di scelta rapida per recuperare i record dal database. Se sei interessato, passa alla sezione Recupero dei risultati, altrimenti passa alla sezione successiva.
Operazione di aggiornamento
AGGIORNAMENTO Operare su qualsiasi database significa aggiornare uno o più record, già disponibili nel database. Di seguito è riportata la procedura per aggiornare tutti i record che hanno SEX come "M". Qui aumenteremo l'ETÀ di tutti i maschi di un anno. Questo richiederà tre passaggi:
Preparazione di query SQL in base alle condizioni richieste. Questo sarà fatto usando ilprepare metodo.
Esecuzione di query SQL per selezionare tutti i risultati dal database. Questo sarà fatto usando ilexecute metodo.
Rilascio dell'handle di istruzione. Questo sarà fatto usando ilfinish metodo.
Se tutto va bene allora commit questa operazione altrimenti puoi rollback la transazione completa.
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare("UPDATE EMPLOYEE SET AGE = AGE + 1 WHERE SEX = ?")
sth.execute('M')
sth.finish
dbh.commit
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
Operazione DELETE
L'operazione DELETE è necessaria quando si desidera eliminare alcuni record dal database. Di seguito è illustrata la procedura per eliminare tutti i record da DIPENDENTE di età superiore a 20. Questa operazione richiederà i passaggi seguenti.
Preparazione di query SQL in base alle condizioni richieste. Questo sarà fatto usando ilprepare metodo.
Esecuzione di query SQL per eliminare i record richiesti dal database. Questo sarà fatto usando ilexecute metodo.
Rilascio dell'handle di istruzione. Questo sarà fatto usando ilfinish metodo.
Se tutto va bene allora commit questa operazione altrimenti puoi rollback la transazione completa.
#!/usr/bin/ruby -w
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
sth = dbh.prepare("DELETE FROM EMPLOYEE WHERE AGE > ?")
sth.execute(20)
sth.finish
dbh.commit
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
Esecuzione di transazioni
Le transazioni sono un meccanismo che garantisce la coerenza dei dati. Le transazioni dovrebbero avere le seguenti quattro proprietà:
Atomicity - O una transazione viene completata o non accade nulla.
Consistency - Una transazione deve iniziare in uno stato coerente e lasciare che il sistema sia uno stato coerente.
Isolation - I risultati intermedi di una transazione non sono visibili al di fuori della transazione corrente.
Durability - Una volta eseguito il commit di una transazione, gli effetti sono persistenti, anche dopo un errore di sistema.
Il DBI fornisce due metodi per eseguire il commit o il rollback di una transazione. C'è un altro metodo chiamato transazione che può essere utilizzato per implementare le transazioni. Esistono due semplici approcci per implementare le transazioni:
Approccio I
Il primo approccio utilizza i metodi di commit e rollback di DBI per eseguire il commit o annullare esplicitamente la transazione -
dbh['AutoCommit'] = false # Set auto commit to false.
begin
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'John'")
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'Zara'")
dbh.commit
rescue
puts "transaction failed"
dbh.rollback
end
dbh['AutoCommit'] = true
Approccio II
Il secondo approccio utilizza il metodo della transazione . Questo è più semplice, perché richiede un blocco di codice contenente le istruzioni che compongono la transazione. Il metodo di transazione esegue il blocco, quindi richiama automaticamente il commit o il rollback , a seconda che il blocco abbia successo o meno -
dbh['AutoCommit'] = false # Set auto commit to false.
dbh.transaction do |dbh|
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'John'")
dbh.do("UPDATE EMPLOYEE SET AGE = AGE+1 WHERE FIRST_NAME = 'Zara'")
end
dbh['AutoCommit'] = true
Operazione COMMIT
Commit è l'operazione, che dà un segnale verde al database per finalizzare le modifiche e, dopo questa operazione, nessuna modifica può essere ripristinata.
Ecco un semplice esempio per chiamare il file commit metodo.
dbh.commit
Operazione ROLLBACK
Se non sei soddisfatto di una o più modifiche e desideri ripristinarle completamente, utilizza il rollback metodo.
Ecco un semplice esempio per chiamare il file rollback metodo.
dbh.rollback
Disconnessione del database
Per disconnettere la connessione al database, utilizzare l'API disconnect.
dbh.disconnect
Se la connessione a un database viene chiusa dall'utente con il metodo di disconnessione, tutte le transazioni in sospeso vengono annullate dal DBI. Tuttavia, invece di dipendere da uno qualsiasi dei dettagli di implementazione di DBI, l'applicazione farebbe meglio a chiamare esplicitamente il commit o il rollback.
Gestione degli errori
Esistono molte fonti di errore. Alcuni esempi sono un errore di sintassi in un'istruzione SQL eseguita, un errore di connessione o la chiamata del metodo fetch per un handle di istruzione già annullato o terminato.
Se un metodo DBI fallisce, DBI solleva un'eccezione. I metodi DBI possono sollevare uno qualsiasi dei diversi tipi di eccezione, ma le due classi di eccezione più importanti sono DBI :: InterfaceError e DBI :: DatabaseError .
Gli oggetti eccezione di queste classi hanno tre attributi denominati err , errstr e state , che rappresentano il numero di errore, una stringa di errore descrittiva e un codice di errore standard. Gli attributi sono spiegati di seguito:
err- Restituisce una rappresentazione intera dell'errore verificatosi o nullo se questo non è supportato dal DBD. Oracle DBD, ad esempio, restituisce la parte numerica di un messaggio di errore ORA-XXXX .
errstr - Restituisce una rappresentazione in formato stringa dell'errore che si è verificato.
state- Restituisce il codice SQLSTATE dell'errore verificato. SQLSTATE è una stringa di cinque caratteri. La maggior parte dei DBD non lo supporta e restituisce invece zero.
Hai visto il seguente codice sopra nella maggior parte degli esempi:
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
dbh.rollback
ensure
# disconnect from server
dbh.disconnect if dbh
end
Per ottenere informazioni di debug su ciò che lo script sta facendo durante l'esecuzione, è possibile abilitare la traccia. Per fare ciò, devi prima caricare il modulo dbi / trace e quindi chiamare il metodo trace che controlla la modalità trace e la destinazione di output -
require "dbi/trace"
..............
trace(mode, destination)
Il valore della modalità può essere 0 (disattivato), 1, 2 o 3 e la destinazione dovrebbe essere un oggetto IO. I valori predefiniti sono rispettivamente 2 e STDERR.
Blocchi di codice con metodi
Esistono alcuni metodi che creano gli handle. Questi metodi possono essere richiamati con un blocco di codice. Il vantaggio dell'utilizzo del blocco di codice insieme ai metodi è che forniscono l'handle al blocco di codice come parametro e puliscono automaticamente l'handle quando il blocco termina. Ci sono pochi esempi per comprendere il concetto.
DBI.connect- Questo metodo genera un handle di database e si consiglia di chiamare disconnect alla fine del blocco per disconnettere il database.
dbh.prepare- Questo metodo genera un handle di istruzione e si consiglia di terminare alla fine del blocco. All'interno del blocco, è necessario richiamare eseguire il metodo per eseguire l'istruzione.
dbh.execute- Questo metodo è simile tranne per il fatto che non è necessario invocare l'esecuzione all'interno del blocco. L'handle dell'istruzione viene eseguito automaticamente.
Esempio 1
DBI.connect può prendere un blocco di codice, passargli l'handle del database e disconnettere automaticamente l'handle alla fine del blocco come segue.
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123") do |dbh|
Esempio 2
dbh.prepare può prendere un blocco di codice, passargli l'handle dell'istruzione e chiamare automaticamente finish alla fine del blocco come segue.
dbh.prepare("SHOW DATABASES") do |sth|
sth.execute
puts "Databases: " + sth.fetch_all.join(", ")
end
Esempio 3
dbh.execute può prendere un blocco di codice, passargli l'handle dell'istruzione e chiamare automaticamente finish alla fine del blocco come segue:
dbh.execute("SHOW DATABASES") do |sth|
puts "Databases: " + sth.fetch_all.join(", ")
end
Il metodo di transazione DBI accetta anche un blocco di codice che è stato descritto sopra.
Funzioni e attributi specifici del driver
Il DBI consente ai driver del database di fornire ulteriori funzioni specifiche del database, che possono essere chiamate dall'utente tramite il metodo func di qualsiasi oggetto Handle.
Gli attributi specifici del driver sono supportati e possono essere impostati o ottenuti utilizzando il []= o [] metodi.
Sr.No. | Funzioni e descrizione |
---|---|
1 | dbh.func(:createdb, db_name) Crea un nuovo database. |
2 | dbh.func(:dropdb, db_name) Elimina un database. |
3 | dbh.func(:reload) Esegue un'operazione di ricarica. |
4 | dbh.func(:shutdown) Arresta il server. |
5 | dbh.func(:insert_id) => Fixnum Restituisce il valore AUTO_INCREMENT più recente per una connessione. |
6 | dbh.func(:client_info) => String Restituisce le informazioni sul client MySQL in termini di versione. |
7 | dbh.func(:client_version) => Fixnum Restituisce le informazioni sul cliente in termini di versione. È simile a: client_info ma restituisce un fixnum invece di sting. |
8 | dbh.func(:host_info) => String Restituisce le informazioni sull'host. |
9 | dbh.func(:proto_info) => Fixnum Restituisce il protocollo utilizzato per la comunicazione. |
10 | dbh.func(:server_info) => String Restituisce le informazioni sul server MySQL in termini di versione. |
11 | dbh.func(:stat) => String Restituisce lo stato corrente del database. |
12 | dbh.func(:thread_id) => Fixnum Restituisce l'ID del thread corrente. |
Esempio
#!/usr/bin/ruby
require "dbi"
begin
# connect to the MySQL server
dbh = DBI.connect("DBI:Mysql:TESTDB:localhost", "testuser", "test123")
puts dbh.func(:client_info)
puts dbh.func(:client_version)
puts dbh.func(:host_info)
puts dbh.func(:proto_info)
puts dbh.func(:server_info)
puts dbh.func(:thread_id)
puts dbh.func(:stat)
rescue DBI::DatabaseError => e
puts "An error occurred"
puts "Error code: #{e.err}"
puts "Error message: #{e.errstr}"
ensure
dbh.disconnect if dbh
end
Questo produrrà il seguente risultato:
5.0.45
50045
Localhost via UNIX socket
10
5.0.45
150621
Uptime: 384981 Threads: 1 Questions: 1101078 Slow queries: 4 \
Opens: 324 Flush tables: 1 Open tables: 64 \
Queries per second avg: 2.860
Ruby è un linguaggio generico; non può essere propriamente chiamato linguaggio web . Anche così, le applicazioni web e gli strumenti web in generale sono tra gli usi più comuni di Ruby.
Non solo puoi scrivere il tuo server SMTP, demone FTP o server Web in Ruby, ma puoi anche usare Ruby per attività più comuni come la programmazione CGI o come sostituto di PHP.
Si prega di trascorrere qualche minuto con CGI Programming Tutorial per maggiori dettagli sulla programmazione CGI.
Scrittura di script CGI
Lo script CGI di Ruby più semplice si presenta così:
#!/usr/bin/ruby
puts "HTTP/1.0 200 OK"
puts "Content-type: text/html\n\n"
puts "<html><body>This is a test</body></html>"
Se chiami questo script test.cgi e lo carichi su un provider di hosting Web basato su Unix con i giusti permessi, potresti usarlo come script CGI.
Ad esempio, se hai il sito Web https://www.example.com/ospitato con un provider di hosting Web Linux e carichi test.cgi nella directory principale e gli dai i permessi di esecuzione, quindi visitihttps://www.example.com/test.cgi dovrebbe restituire una pagina HTML che dice This is a test.
Qui, quando test.cgi viene richiesto da un browser Web, il server Web cerca test.cgi sul sito Web e quindi lo esegue utilizzando l'interprete Ruby. Lo script Ruby restituisce un'intestazione HTTP di base e quindi restituisce un documento HTML di base.
Utilizzando cgi.rb
Ruby viene fornito con una libreria speciale chiamata cgi che consente interazioni più sofisticate rispetto a quelle con lo script CGI precedente.
Creiamo uno script CGI di base che utilizzi cgi -
#!/usr/bin/ruby
require 'cgi'
cgi = CGI.new
puts cgi.header
puts "<html><body>This is a test</body></html>"
Qui, hai creato un oggetto CGI e lo hai usato per stampare la riga di intestazione per te.
Elaborazione del modulo
L'uso della classe CGI ti dà accesso ai parametri di query HTML in due modi. Supponiamo che ci venga fornito un URL di /cgi-bin/test.cgi?FirstName = Zara & LastName = Ali.
È possibile accedere ai parametri FirstName e LastName utilizzando CGI # [] direttamente come segue:
#!/usr/bin/ruby
require 'cgi'
cgi = CGI.new
cgi['FirstName'] # => ["Zara"]
cgi['LastName'] # => ["Ali"]
C'è un altro modo per accedere a queste variabili del modulo. Questo codice ti darà un hash di tutte le chiavi e i valori -
#!/usr/bin/ruby
require 'cgi'
cgi = CGI.new
h = cgi.params # => {"FirstName"=>["Zara"],"LastName"=>["Ali"]}
h['FirstName'] # => ["Zara"]
h['LastName'] # => ["Ali"]
Di seguito è riportato il codice per recuperare tutte le chiavi:
#!/usr/bin/ruby
require 'cgi'
cgi = CGI.new
cgi.keys # => ["FirstName", "LastName"]
Se un modulo contiene più campi con lo stesso nome, i valori corrispondenti verranno restituiti allo script come un array. La funzione di accesso [] restituisce solo il primo di these.index il risultato del metodo params per ottenerli tutti.
In questo esempio, supponi che il modulo abbia tre campi chiamati "nome" e abbiamo inserito tre nomi "Zara", "Huma" e "Nuha" -
#!/usr/bin/ruby
require 'cgi'
cgi = CGI.new
cgi['name'] # => "Zara"
cgi.params['name'] # => ["Zara", "Huma", "Nuha"]
cgi.keys # => ["name"]
cgi.params # => {"name"=>["Zara", "Huma", "Nuha"]}
Note- Ruby si prenderà cura dei metodi GET e POST automaticamente. Non esiste un trattamento separato per questi due metodi diversi.
Un modulo associato, ma di base, che potrebbe inviare i dati corretti avrebbe il codice HTML in questo modo:
<html>
<body>
<form method = "POST" action = "http://www.example.com/test.cgi">
First Name :<input type = "text" name = "FirstName" value = "" />
<br />
Last Name :<input type = "text" name = "LastName" value = "" />
<input type = "submit" value = "Submit Data" />
</form>
</body>
</html>
Creazione di moduli e HTML
CGI contiene un numero enorme di metodi utilizzati per creare HTML. Troverai un metodo per tag. Per abilitare questi metodi, è necessario creare un oggetto CGI chiamando CGI.new.
Per rendere più facile la nidificazione dei tag, questi metodi prendono il loro contenuto come blocchi di codice. I blocchi di codice dovrebbero restituire una stringa , che verrà utilizzata come contenuto per il tag. Ad esempio:
#!/usr/bin/ruby
require "cgi"
cgi = CGI.new("html4")
cgi.out {
cgi.html {
cgi.head { "\n"+cgi.title{"This Is a Test"} } +
cgi.body { "\n"+
cgi.form {"\n"+
cgi.hr +
cgi.h1 { "A Form: " } + "\n"+
cgi.textarea("get_text") +"\n"+
cgi.br +
cgi.submit
}
}
}
}
NOTE- Il metodo form della classe CGI può accettare un parametro di metodo, che imposterà il metodo HTTP (GET, POST e così via ...) da utilizzare durante l'invio del modulo. L'impostazione predefinita, utilizzata in questo esempio, è POST.
Questo produrrà il seguente risultato:
Content-Type: text/html
Content-Length: 302
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Final//EN">
<HTML>
<HEAD>
<TITLE>This Is a Test</TITLE>
</HEAD>
<BODY>
<FORM METHOD = "post" ENCTYPE = "application/x-www-form-urlencoded">
<HR>
<H1>A Form: </H1>
<TEXTAREA COLS = "70" NAME = "get_text" ROWS = "10"></TEXTAREA>
<BR>
<INPUT TYPE = "submit">
</FORM>
</BODY>
</HTML>
Citando stringhe
Quando si tratta di URL e codice HTML, è necessario fare attenzione a citare determinati caratteri. Ad esempio, un carattere barra (/) ha un significato speciale in un URL, quindi deve esserloescaped se non fa parte del percorso.
Ad esempio, qualsiasi / nella parte della query dell'URL verrà tradotta nella stringa% 2F e dovrà essere tradotta di nuovo in una / per poterla utilizzare. Anche lo spazio e la e commerciale sono caratteri speciali. Per gestire questo, CGI fornisce le routineCGI.escape e CGI.unescape.
#!/usr/bin/ruby
require 'cgi'
puts CGI.escape(Zara Ali/A Sweet & Sour Girl")
Questo produrrà il seguente risultato:
Zara+Ali%2FA Sweet+%26+Sour+Girl")
#!/usr/bin/ruby
require 'cgi'
puts CGI.escapeHTML('<h1>Zara Ali/A Sweet & Sour Girl</h1>')
Questo produrrà il seguente risultato:
<h1>Zara Ali/A Sweet & Sour Girl</h1>'
Metodi utili nella classe CGI
Ecco l'elenco dei metodi relativi alla classe CGI -
The Ruby CGI - Metodi relativi alla libreria CGI standard.
Cookie e sessioni
Abbiamo spiegato questi due concetti in diverse sezioni. Si prega di seguire le sezioni -
I cookie CGI di Ruby - Come gestire i cookie CGI.
Le sessioni CGI di Ruby - Come gestire le sessioni CGI.
Server di hosting web
È possibile controllare il seguente argomento su Internet per ospitare il proprio sito Web su un server basato su Unix:
Hosting Web basato su Unix
Il protocollo SMTP (Simple Mail Transfer Protocol) è un protocollo che gestisce l'invio di posta elettronica e il routing della posta tra i server di posta.
Ruby fornisce la classe Net :: SMTP per la connessione lato client SMTP (Simple Mail Transfer Protocol) e fornisce due metodi di classe new e start .
Il new accetta due parametri -
Il nome del server predefinito su localhost.
Il numero di porta predefinito per la nota porta 25.
Il start il metodo accetta questi parametri:
Il server : nome IP del server SMTP, predefinito su localhost.
La porta : numero di porta, il valore predefinito è 25.
Il dominio - Dominio del mittente della posta, predefinito su ENV ["HOSTNAME"].
L' account - Nome utente, l'impostazione predefinita è zero.
La password - Password utente, predefinita a zero.
Il tipo di autenticazione : tipo di autorizzazione, predefinito cram_md5 .
Un oggetto SMTP dispone di un metodo di istanza chiamato sendmail, che in genere verrà utilizzato per eseguire il lavoro di spedizione di un messaggio. Ci vogliono tre parametri:
La fonte - Una stringa o un array o qualsiasi cosa con una ogni iteratore ritorno una corda alla volta.
Il mittente - Una stringa che apparirà nel dal campo della e-mail.
I destinatari : una stringa o un array di stringhe che rappresentano i destinatari dei destinatari.
Esempio
Ecco un modo semplice per inviare un'e-mail utilizzando lo script Ruby. Provalo una volta -
require 'net/smtp'
message = <<MESSAGE_END
From: Private Person <[email protected]>
To: A Test User <[email protected]>
Subject: SMTP e-mail test
This is a test e-mail message.
MESSAGE_END
Net::SMTP.start('localhost') do |smtp|
smtp.send_message message, '[email protected]', '[email protected]'
end
Qui hai inserito un messaggio di posta elettronica di base nel messaggio, utilizzando un documento, avendo cura di formattare correttamente le intestazioni. Le e-mail richiedono un fileFrom, To, e Subject intestazione, separata dal corpo dell'e-mail con una riga vuota.
Per inviare la posta si utilizza Net :: SMTP per connettersi al server SMTP sulla macchina locale e quindi utilizzare il metodo send_message insieme al messaggio, all'indirizzo del mittente e all'indirizzo di destinazione come parametri (anche se gli indirizzi da e a all'interno della posta elettronica stessa, questi non sono sempre utilizzati per instradare la posta).
Se non stai eseguendo un server SMTP sulla tua macchina, puoi usare Net :: SMTP per comunicare con un server SMTP remoto. A meno che tu non stia utilizzando un servizio di webmail (come Hotmail o Yahoo! Mail), il tuo provider di posta elettronica ti fornirà i dettagli del server di posta in uscita che puoi fornire a Net :: SMTP, come segue:
Net::SMTP.start('mail.your-domain.com')
Questa riga di codice si collega al server SMTP sulla porta 25 di mail.tuo-dominio.com senza utilizzare alcun nome utente o password. Se necessario, tuttavia, è possibile specificare il numero di porta e altri dettagli. Ad esempio:
Net::SMTP.start('mail.your-domain.com',
25,
'localhost',
'username', 'password' :plain)
Questo esempio si connette al server SMTP all'indirizzo mail.tuo-dominio.com utilizzando un nome utente e una password in formato di testo normale. Identifica il nome host del client come localhost.
Invio di un'e-mail HTML utilizzando Ruby
Quando invii un messaggio di testo utilizzando Ruby, tutto il contenuto verrà trattato come testo semplice. Anche se includerai tag HTML in un messaggio di testo, verrà visualizzato come testo semplice e i tag HTML non verranno formattati secondo la sintassi HTML. Ma Ruby Net :: SMTP fornisce l'opzione per inviare un messaggio HTML come messaggio HTML effettivo.
Durante l'invio di un messaggio di posta elettronica è possibile specificare una versione Mime, un tipo di contenuto e un set di caratteri per inviare un messaggio di posta elettronica HTML.
Esempio
Di seguito è riportato l'esempio per inviare contenuto HTML come posta elettronica. Provalo una volta -
require 'net/smtp'
message = <<MESSAGE_END
From: Private Person <[email protected]>
To: A Test User <[email protected]>
MIME-Version: 1.0
Content-type: text/html
Subject: SMTP e-mail test
This is an e-mail message to be sent in HTML format
<b>This is HTML message.</b>
<h1>This is headline.</h1>
MESSAGE_END
Net::SMTP.start('localhost') do |smtp|
smtp.send_message message, '[email protected]', '[email protected]'
end
Invio di allegati come e-mail
Per inviare un'e-mail con contenuto misto è necessario impostare Content-type intestazione a multipart/mixed. Quindi le sezioni di testo e allegato possono essere specificate all'internoboundaries.
Un confine inizia con due trattini seguiti da un numero univoco, che non può comparire nella parte del messaggio dell'email. Anche un confine finale che denota la sezione finale dell'email deve terminare con due trattini.
I file allegati dovrebbero essere codificati con l'estensione pack("m") funzione per avere la codifica base64 prima della trasmissione.
Esempio
Di seguito è riportato l'esempio, che invierà un file /tmp/test.txt come un allegato.
require 'net/smtp'
filename = "/tmp/test.txt"
# Read a file and encode it into base64 format
filecontent = File.read(filename)
encodedcontent = [filecontent].pack("m") # base64
marker = "AUNIQUEMARKER"
body = <<EOF
This is a test email to send an attachement.
EOF
# Define the main headers.
part1 = <<EOF
From: Private Person <[email protected]>
To: A Test User <[email protected]>
Subject: Sending Attachement
MIME-Version: 1.0
Content-Type: multipart/mixed; boundary = #{marker}
--#{marker}
EOF
# Define the message action
part2 = <<EOF
Content-Type: text/plain
Content-Transfer-Encoding:8bit
#{body}
--#{marker}
EOF
# Define the attachment section
part3 = <<EOF
Content-Type: multipart/mixed; name = \"#{filename}\"
Content-Transfer-Encoding:base64
Content-Disposition: attachment; filename = "#{filename}"
#{encodedcontent}
--#{marker}--
EOF
mailtext = part1 + part2 + part3
# Let's put our code in safe area
begin
Net::SMTP.start('localhost') do |smtp|
smtp.sendmail(mailtext, '[email protected]', ['[email protected]'])
end
rescue Exception => e
print "Exception occured: " + e
end
NOTE - È possibile specificare più destinazioni all'interno dell'array, ma devono essere separate da virgola.
Ruby fornisce due livelli di accesso ai servizi di rete. A un livello basso, è possibile accedere al supporto socket di base nel sistema operativo sottostante, che consente di implementare client e server per protocolli orientati alla connessione e senza connessione.
Ruby dispone anche di librerie che forniscono un accesso di livello superiore a specifici protocolli di rete a livello di applicazione, come FTP, HTTP e così via.
Questo capitolo fornisce una comprensione dei concetti più famosi in Networking - Socket Programming.
Cosa sono i socket?
I socket sono gli endpoint di un canale di comunicazione bidirezionale. I socket possono comunicare all'interno di un processo, tra processi sulla stessa macchina o tra processi su continenti diversi.
I socket possono essere implementati su diversi tipi di canali: socket di dominio Unix, TCP, UDP e così via. Il socket fornisce classi specifiche per la gestione dei trasporti comuni, nonché un'interfaccia generica per la gestione del resto.
Le prese hanno il loro vocabolario -
Sr.No. | Termine e descrizione |
---|---|
1 | domain La famiglia di protocolli che verrà utilizzata come meccanismo di trasporto. Questi valori sono costanti come PF_INET, PF_UNIX, PF_X25 e così via. |
2 | type Il tipo di comunicazione tra i due endpoint, in genere SOCK_STREAM per i protocolli orientati alla connessione e SOCK_DGRAM per i protocolli senza connessione. |
3 | protocol Tipicamente zero, può essere utilizzato per identificare una variante di un protocollo all'interno di un dominio e tipo. |
4 | hostname L'identificatore di un'interfaccia di rete - Una stringa, che può essere un nome host, un indirizzo con quattro punti o un indirizzo IPV6 in notazione con due punti (e possibilmente con un punto) Una stringa "<broadcast>", che specifica un indirizzo INADDR_BROADCAST. Una stringa di lunghezza zero, che specifica INADDR_ANY o Un numero intero, interpretato come un indirizzo binario nell'ordine dei byte dell'host. |
5 | port Ogni server ascolta i client che chiamano su una o più porte. Una porta può essere un numero di porta Fixnum, una stringa contenente un numero di porta o il nome di un servizio. |
Un semplice cliente
Qui scriveremo un programma client molto semplice, che aprirà una connessione a una data porta e un determinato host. Classe RubyTCPSocketfornisce la funzione open per aprire tale socket.
Il TCPSocket.open(hosname, port )apre una connessione TCP al nome host sulla porta .
Una volta aperto un socket, puoi leggere da esso come qualsiasi oggetto IO. Quando hai finito, ricordati di chiuderlo, come faresti per chiudere un file.
Il codice seguente è un client molto semplice che si connette a un determinato host e porta, legge tutti i dati disponibili dal socket e quindi esce:
require 'socket' # Sockets are in standard library
hostname = 'localhost'
port = 2000
s = TCPSocket.open(hostname, port)
while line = s.gets # Read lines from the socket
puts line.chop # And print with platform line terminator
end
s.close # Close the socket when done
Un semplice server
Per scrivere server Internet, utilizziamo il TCPServerclasse. Un oggetto TCPServer è una factory per oggetti TCPSocket.
Adesso chiama TCPServer.open(hostname, portfunzione per specificare una porta per il servizio e creare un fileTCPServer oggetto.
Avanti, chiamare il accettano metodo dell'oggetto TCPServer restituito. Questo metodo attende che un client si connetta alla porta specificata, quindi restituisce un oggetto TCPSocket che rappresenta la connessione a quel client.
require 'socket' # Get sockets from stdlib
server = TCPServer.open(2000) # Socket to listen on port 2000
loop { # Servers run forever
client = server.accept # Wait for a client to connect
client.puts(Time.now.ctime) # Send the time to the client
client.puts "Closing the connection. Bye!"
client.close # Disconnect from the client
}
Ora, esegui questo server in background e quindi esegui il client sopra per vedere il risultato.
Server TCP multi-client
La maggior parte dei server su Internet è progettata per gestire un gran numero di client in qualsiasi momento.
La classe Thread di Ruby semplifica la creazione di un server multithread. Uno che accetta le richieste e crea immediatamente un nuovo thread di esecuzione per elaborare la connessione consentendo al programma principale di attendere più connessioni -
require 'socket' # Get sockets from stdlib
server = TCPServer.open(2000) # Socket to listen on port 2000
loop { # Servers run forever
Thread.start(server.accept) do |client|
client.puts(Time.now.ctime) # Send the time to the client
client.puts "Closing the connection. Bye!"
client.close # Disconnect from the client
end
}
In questo esempio, si ha un ciclo permanente e quando server.accept risponde, viene creato e avviato immediatamente un nuovo thread per gestire la connessione appena accettata, utilizzando l'oggetto connessione passato nel thread. Tuttavia, il programma principale torna immediatamente indietro e attende nuove connessioni.
Usare i thread Ruby in questo modo significa che il codice è portabile e verrà eseguito allo stesso modo su Linux, OS X e Windows.
Un minuscolo browser web
Possiamo usare la libreria socket per implementare qualsiasi protocollo Internet. Ecco, ad esempio, un codice per recuperare il contenuto di una pagina web:
require 'socket'
host = 'www.tutorialspoint.com' # The web server
port = 80 # Default HTTP port
path = "/index.htm" # The file we want
# This is the HTTP request we send to fetch a file
request = "GET #{path} HTTP/1.0\r\n\r\n"
socket = TCPSocket.open(host,port) # Connect to server
socket.print(request) # Send request
response = socket.read # Read complete response
# Split response at first blank line into headers and body
headers,body = response.split("\r\n\r\n", 2)
print body # And display it
Per implementare il client Web simile, puoi utilizzare una libreria predefinita come Net::HTTPper lavorare con HTTP. Ecco il codice che fa l'equivalente del codice precedente -
require 'net/http' # The library we need
host = 'www.tutorialspoint.com' # The web server
path = '/index.htm' # The file we want
http = Net::HTTP.new(host) # Create a connection
headers, body = http.get(path) # Request the file
if headers.code == "200" # Check the status code
print body
else
puts "#{headers.code} #{headers.message}"
end
Verificare che librerie simili funzionino con i protocolli FTP, SMTP, POP e IMAP.
Ulteriori letture
Ti abbiamo dato un rapido avvio sulla programmazione Socket. È un argomento importante, quindi si consiglia di consultare Ruby Socket Library e Class Methods per trovare maggiori dettagli.
Cos'è l'XML?
L'Extensible Markup Language (XML) è un linguaggio di markup molto simile a HTML o SGML. Questo è consigliato dal World Wide Web Consortium e disponibile come standard aperto.
XML è un linguaggio portatile e open source che consente ai programmatori di sviluppare applicazioni che possono essere lette da altre applicazioni, indipendentemente dal sistema operativo e / o dal linguaggio di sviluppo.
XML è estremamente utile per tenere traccia di piccole e medie quantità di dati senza richiedere un backbone basato su SQL.
API e architetture di parser XML
Sono disponibili due diversi gusti per i parser XML:
SAX-like (Stream interfaces)- Qui si registrano i callback per gli eventi di interesse e quindi si lascia che il parser proceda attraverso il documento. Ciò è utile quando i tuoi documenti sono di grandi dimensioni o hai limitazioni di memoria, analizza il file mentre lo legge dal disco e l'intero file non viene mai archiviato in memoria.
DOM-like (Object tree interfaces) - Questa è la raccomandazione del World Wide Web Consortium in cui l'intero file viene letto in memoria e archiviato in una forma gerarchica (basata su albero) per rappresentare tutte le caratteristiche di un documento XML.
Ovviamente SAX non può elaborare le informazioni alla velocità di DOM quando si lavora con file di grandi dimensioni. D'altra parte, l'uso esclusivo di DOM può davvero uccidere le tue risorse, specialmente se usato su molti piccoli file.
SAX è di sola lettura, mentre DOM consente modifiche al file XML. Poiché queste due API diverse si completano letteralmente a vicenda, non c'è motivo per cui non puoi usarle entrambe per progetti di grandi dimensioni.
Analisi e creazione di XML utilizzando Ruby
Il modo più comune per manipolare XML è con la libreria REXML di Sean Russell. Dal 2002, REXML fa parte della distribuzione standard di Ruby.
REXML è un processore XML puro Ruby conforme allo standard XML 1.0. È un processore non convalidante , che supera tutti i test di conformità non convalidanti OASIS.
Il parser REXML presenta i seguenti vantaggi rispetto ad altri parser disponibili:
- È scritto al 100 percento in Ruby.
- Può essere utilizzato sia per l'analisi SAX che per quella DOM.
- È leggero, meno di 2000 righe di codice.
- I metodi e le classi sono davvero facili da capire.
- API basata su SAX2 e supporto completo di XPath.
- Viene fornito con l'installazione di Ruby e non è richiesta alcuna installazione separata.
Per tutti i nostri esempi di codice XML, utilizziamo un semplice file XML come input -
<collection shelf = "New Arrivals">
<movie title = "Enemy Behind">
<type>War, Thriller</type>
<format>DVD</format>
<year>2003</year>
<rating>PG</rating>
<stars>10</stars>
<description>Talk about a US-Japan war</description>
</movie>
<movie title = "Transformers">
<type>Anime, Science Fiction</type>
<format>DVD</format>
<year>1989</year>
<rating>R</rating>
<stars>8</stars>
<description>A schientific fiction</description>
</movie>
<movie title = "Trigun">
<type>Anime, Action</type>
<format>DVD</format>
<episodes>4</episodes>
<rating>PG</rating>
<stars>10</stars>
<description>Vash the Stampede!</description>
</movie>
<movie title = "Ishtar">
<type>Comedy</type>
<format>VHS</format>
<rating>PG</rating>
<stars>2</stars>
<description>Viewable boredom</description>
</movie>
</collection>
Analisi simile a DOM
Analizziamo prima i nostri dati XML in modo albero . Iniziamo richiedendo il filerexml/documentbiblioteca; spesso facciamo un REXML di inclusione da importare nello spazio dei nomi di primo livello per comodità.
#!/usr/bin/ruby -w
require 'rexml/document'
include REXML
xmlfile = File.new("movies.xml")
xmldoc = Document.new(xmlfile)
# Now get the root element
root = xmldoc.root
puts "Root element : " + root.attributes["shelf"]
# This will output all the movie titles.
xmldoc.elements.each("collection/movie"){
|e| puts "Movie Title : " + e.attributes["title"]
}
# This will output all the movie types.
xmldoc.elements.each("collection/movie/type") {
|e| puts "Movie Type : " + e.text
}
# This will output all the movie description.
xmldoc.elements.each("collection/movie/description") {
|e| puts "Movie Description : " + e.text
}
Questo produrrà il seguente risultato:
Root element : New Arrivals
Movie Title : Enemy Behind
Movie Title : Transformers
Movie Title : Trigun
Movie Title : Ishtar
Movie Type : War, Thriller
Movie Type : Anime, Science Fiction
Movie Type : Anime, Action
Movie Type : Comedy
Movie Description : Talk about a US-Japan war
Movie Description : A schientific fiction
Movie Description : Vash the Stampede!
Movie Description : Viewable boredom
Analisi simile a SAX
Per elaborare gli stessi dati, movies.xml , file in modo orientato al flusso definiremo una classe listener i cui metodi saranno l'obiettivo dei callback dal parser.
NOTE - Non è consigliabile utilizzare l'analisi simile a SAX per un piccolo file, questo è solo per un esempio demo.
#!/usr/bin/ruby -w
require 'rexml/document'
require 'rexml/streamlistener'
include REXML
class MyListener
include REXML::StreamListener
def tag_start(*args)
puts "tag_start: #{args.map {|x| x.inspect}.join(', ')}"
end
def text(data)
return if data =~ /^\w*$/ # whitespace only
abbrev = data[0..40] + (data.length > 40 ? "..." : "")
puts " text : #{abbrev.inspect}"
end
end
list = MyListener.new
xmlfile = File.new("movies.xml")
Document.parse_stream(xmlfile, list)
Questo produrrà il seguente risultato:
tag_start: "collection", {"shelf"=>"New Arrivals"}
tag_start: "movie", {"title"=>"Enemy Behind"}
tag_start: "type", {}
text : "War, Thriller"
tag_start: "format", {}
tag_start: "year", {}
tag_start: "rating", {}
tag_start: "stars", {}
tag_start: "description", {}
text : "Talk about a US-Japan war"
tag_start: "movie", {"title"=>"Transformers"}
tag_start: "type", {}
text : "Anime, Science Fiction"
tag_start: "format", {}
tag_start: "year", {}
tag_start: "rating", {}
tag_start: "stars", {}
tag_start: "description", {}
text : "A schientific fiction"
tag_start: "movie", {"title"=>"Trigun"}
tag_start: "type", {}
text : "Anime, Action"
tag_start: "format", {}
tag_start: "episodes", {}
tag_start: "rating", {}
tag_start: "stars", {}
tag_start: "description", {}
text : "Vash the Stampede!"
tag_start: "movie", {"title"=>"Ishtar"}
tag_start: "type", {}
tag_start: "format", {}
tag_start: "rating", {}
tag_start: "stars", {}
tag_start: "description", {}
text : "Viewable boredom"
XPath e Ruby
Un modo alternativo per visualizzare XML è XPath. Questo è un tipo di pseudo-linguaggio che descrive come individuare elementi e attributi specifici in un documento XML, trattando quel documento come un albero logico ordinato.
REXML ha il supporto XPath tramite la classe XPath . Presuppone l'analisi basata sugli alberi (modello a oggetti del documento) come abbiamo visto sopra.
#!/usr/bin/ruby -w
require 'rexml/document'
include REXML
xmlfile = File.new("movies.xml")
xmldoc = Document.new(xmlfile)
# Info for the first movie found
movie = XPath.first(xmldoc, "//movie")
p movie
# Print out all the movie types
XPath.each(xmldoc, "//type") { |e| puts e.text }
# Get an array of all of the movie formats.
names = XPath.match(xmldoc, "//format").map {|x| x.text }
p names
Questo produrrà il seguente risultato:
<movie title = 'Enemy Behind'> ... </>
War, Thriller
Anime, Science Fiction
Anime, Action
Comedy
["DVD", "DVD", "DVD", "VHS"]
XSLT e Ruby
Sono disponibili due parser XSLT che Ruby può usare. Di seguito viene fornita una breve descrizione di ciascuno.
Ruby-Sablotron
Questo parser è scritto e mantenuto da Masayoshi Takahashi. È scritto principalmente per il sistema operativo Linux e richiede le seguenti librerie:
- Sablot
- Iconv
- Expat
Puoi trovare questo modulo su Ruby-Sablotron.
XSLT4R
XSLT4R è scritto da Michael Neumann e può essere trovato presso RAA nella sezione Library sotto XML. XSLT4R utilizza una semplice interfaccia a riga di comando, sebbene possa in alternativa essere utilizzata all'interno di un'applicazione di terze parti per trasformare un documento XML.
XSLT4R richiede XMLScan per funzionare, che è incluso nell'archivio XSLT4R e che è anche un modulo Ruby al 100%. Questi moduli possono essere installati utilizzando il metodo di installazione standard di Ruby (ad esempio, ruby install.rb).
XSLT4R ha la seguente sintassi:
ruby xslt.rb stylesheet.xsl document.xml [arguments]
Se desideri utilizzare XSLT4R da un'applicazione, puoi includere XSLT e inserire i parametri di cui hai bisogno. Ecco l'esempio:
require "xslt"
stylesheet = File.readlines("stylesheet.xsl").to_s
xml_doc = File.readlines("document.xml").to_s
arguments = { 'image_dir' => '/....' }
sheet = XSLT::Stylesheet.new( stylesheet, arguments )
# output to StdOut
sheet.apply( xml_doc )
# output to 'str'
str = ""
sheet.output = [ str ]
sheet.apply( xml_doc )
Ulteriori letture
Per un dettaglio completo su REXML Parser, fare riferimento alla documentazione standard per REXML Parser Documentation .
Puoi scaricare XSLT4R da RAA Repository .
Cos'è SOAP?
Il Simple Object Access Protocol (SOAP), è un protocollo RPC multipiattaforma e indipendente dal linguaggio basato su XML e, solitamente (ma non necessariamente) HTTP.
Utilizza XML per codificare le informazioni che effettuano la chiamata di procedura remota e HTTP per trasportare tali informazioni attraverso una rete dai client ai server e viceversa.
SOAP presenta diversi vantaggi rispetto ad altre tecnologie come COM, CORBA, ecc: ad esempio, i suoi costi di distribuzione e debug relativamente economici, la sua estensibilità e facilità d'uso e l'esistenza di diverse implementazioni per diversi linguaggi e piattaforme.
Si prega di fare riferimento al nostro semplice tutorial SOAP per capirlo in dettaglio.
Questo capitolo ti rende familiare con l'implementazione SOAP per Ruby (SOAP4R). Questo è un tutorial di base, quindi se hai bisogno di un dettaglio approfondito, dovresti fare riferimento ad altre risorse.
Installazione di SOAP4R
SOAP4R è l'implementazione SOAP per Ruby sviluppata da Hiroshi Nakamura e può essere scaricata da -
NOTE - Potrebbe esserci una grande possibilità che tu abbia già installato questo componente.
Download SOAP
Se sei a conoscenza di gem quindi è possibile utilizzare il seguente comando per installare SOAP4R e relativi pacchetti.
$ gem install soap4r --include-dependencies
Se stai lavorando su Windows, devi scaricare un file zippato dalla posizione sopra e devi installarlo utilizzando il metodo di installazione standard eseguendo ruby install.rb .
Scrittura di server SOAP4R
SOAP4R supporta due diversi tipi di server:
- Basato su CGI / FastCGI (SOAP :: RPC :: CGIStub)
- Standalone (SOAP :: RPC: StandaloneServer)
Questo capitolo fornisce dettagli sulla scrittura di un server autonomo. I seguenti passaggi sono coinvolti nella scrittura di un server SOAP.
Passaggio 1: ereditare la classe SOAP :: RPC :: StandaloneServer
Per implementare il proprio server autonomo è necessario scrivere una nuova classe, che sarà figlia di SOAP :: StandaloneServer come segue:
class MyServer < SOAP::RPC::StandaloneServer
...............
end
NOTE- Se vuoi scrivere un server basato su FastCGI, devi prendere SOAP :: RPC :: CGIStub come classe genitore, il resto della procedura rimarrà la stessa.
Passaggio 2: definizione dei metodi del gestore
Il secondo passo è scrivere i metodi dei servizi Web che vorresti esporre al mondo esterno.
Possono essere scritti come semplici metodi Ruby. Ad esempio, scriviamo due metodi per aggiungere due numeri e dividere due numeri:
class MyServer < SOAP::RPC::StandaloneServer
...............
# Handler methods
def add(a, b)
return a + b
end
def div(a, b)
return a / b
end
end
Passaggio 3: esporre i metodi del gestore
Il prossimo passo è aggiungere i nostri metodi definiti al nostro server. Il metodo initialize viene utilizzato per esporre i metodi di servizio con uno dei due metodi seguenti:
class MyServer < SOAP::RPC::StandaloneServer
def initialize(*args)
add_method(receiver, methodName, *paramArg)
end
end
Ecco la descrizione dei parametri:
Sr.No. | Parametro e descrizione |
---|---|
1 | receiver L'oggetto che contiene il metodo methodName. I metodi di servizio vengono definiti nella stessa classe del metodo methodDef, questo parametro è self . |
2 | methodName Il nome del metodo chiamato a causa di una richiesta RPC. |
3 | paramArg Specifica, quando forniti, i nomi dei parametri e le modalità dei parametri. |
Per comprendere l'utilizzo dei parametri inout o out , considerare il seguente metodo di servizio che accetta due parametri (inParam e inoutParam), restituisce un valore di ritorno normale (retVal) e due ulteriori parametri: inoutParam e outParam -
def aMeth(inParam, inoutParam)
retVal = inParam + inoutParam
outParam = inParam . inoutParam
inoutParam = inParam * inoutParam
return retVal, inoutParam, outParam
end
Ora possiamo esporre questo metodo come segue:
add_method(self, 'aMeth', [
%w(in inParam),
%w(inout inoutParam),
%w(out outParam),
%w(retval return)
])
Passaggio 4: avviare il server
Il passaggio finale consiste nell'avviare il server creando un'istanza della classe derivata e chiamando start metodo.
myServer = MyServer.new('ServerName', 'urn:ruby:ServiceName', hostname, port)
myServer.start
Ecco la descrizione dei parametri richiesti -
Sr.No. | Parametro e descrizione |
---|---|
1 | ServerName Un nome di server, puoi dare quello che ti piace di più. |
2 | urn:ruby:ServiceName Qui urna: ruby è costante ma puoi dare un nome ServiceName univoco per questo server. |
3 | hostname Specifica il nome host su cui questo server ascolterà. |
4 | port Un numero di porta disponibile da utilizzare per il servizio web. |
Esempio
Ora, utilizzando i passaggi precedenti, scriviamo un server autonomo:
require "soap/rpc/standaloneserver"
begin
class MyServer < SOAP::RPC::StandaloneServer
# Expose our services
def initialize(*args)
add_method(self, 'add', 'a', 'b')
add_method(self, 'div', 'a', 'b')
end
# Handler methods
def add(a, b)
return a + b
end
def div(a, b)
return a / b
end
end
server = MyServer.new("MyServer",
'urn:ruby:calculation', 'localhost', 8080)
trap('INT){
server.shutdown
}
server.start
rescue => err
puts err.message
end
Quando viene eseguita, questa applicazione server avvia un server SOAP autonomo su localhost e ascolta le richieste sulla porta 8080. Espone un metodo di servizio, add e div , che accetta due parametri e restituisce il risultato.
Ora puoi eseguire questo server in background come segue:
$ ruby MyServer.rb&
Scrittura di client SOAP4R
La classe SOAP :: RPC :: Driver fornisce il supporto per la scrittura di applicazioni client SOAP. Questo capitolo descrive questa classe e dimostra il suo utilizzo sulla base di un'applicazione.
Di seguito sono riportate le informazioni minime necessarie per chiamare un servizio SOAP:
- L'URL del servizio SOAP (SOAP Endpoint URL).
- Lo spazio dei nomi dei metodi del servizio (Method Namespace URI).
- I nomi dei metodi di servizio e i relativi parametri.
Ora scriveremo un client SOAP che chiamerebbe i metodi di servizio definiti nell'esempio precedente, denominato add e div .
Ecco i passaggi principali per creare un client SOAP.
Passaggio 1: creare un'istanza del driver SOAP
Creiamo un'istanza di SOAP :: RPC :: Driver chiamando il suo nuovo metodo come segue:
SOAP::RPC::Driver.new(endPoint, nameSpace, soapAction)
Ecco la descrizione dei parametri richiesti -
Sr.No. | Parametro e descrizione |
---|---|
1 | endPoint URL del server SOAP a cui connettersi. |
2 | nameSpace Lo spazio dei nomi da utilizzare per tutti gli RPC eseguiti con questo oggetto SOAP :: RPC :: Driver. |
3 | soapAction Un valore per il campo SOAPAction dell'intestazione HTTP. Se nullo, il valore predefinito è la stringa vuota "". |
Passaggio 2: aggiungere metodi di servizio
Per aggiungere un metodo di servizio SOAP a SOAP :: RPC :: Driver possiamo chiamare il seguente metodo usando SOAP :: RPC :: Driver instance -
driver.add_method(name, *paramArg)
Ecco la descrizione dei parametri:
Sr.No. | Parametro e descrizione |
---|---|
1 | name Il nome del metodo del servizio Web remoto. |
2 | paramArg Specifica i nomi dei parametri delle procedure remote. |
Passaggio 3: richiama il servizio SOAP
Il passaggio finale consiste nel fatturare il servizio SOAP utilizzando l' istanza SOAP :: RPC :: Driver come segue:
result = driver.serviceMethod(paramArg...)
Qui serviceMethod è il metodo del servizio Web effettivo e paramArg ... è i parametri dell'elenco richiesti per passare il metodo del servizio.
Example
Sulla base dei passaggi precedenti, scriveremo un client SOAP come segue:
#!/usr/bin/ruby -w
require 'soap/rpc/driver'
NAMESPACE = 'urn:ruby:calculation'
URL = 'http://localhost:8080/'
begin
driver = SOAP::RPC::Driver.new(URL, NAMESPACE)
# Add remote sevice methods
driver.add_method('add', 'a', 'b')
# Call remote service methods
puts driver.add(20, 30)
rescue => err
puts err.message
end
Ulteriori letture
Ti ho spiegato solo i concetti di base dei servizi Web con Ruby. Se vuoi approfondirlo ulteriormente, c'è il seguente link per trovare maggiori dettagli sui servizi Web con Ruby .
introduzione
L'interfaccia utente grafica (GUI) standard per Ruby è Tk. Tk è nato come GUI per il linguaggio di scripting Tcl sviluppato da John Ousterhout.
Tk ha la particolarità di essere l'unica GUI multipiattaforma. Tk funziona su Windows, Mac e Linux e fornisce un aspetto nativo su ogni sistema operativo.
Il componente di base di un'applicazione basata su Tk è chiamato widget. Un componente è talvolta chiamato anche una finestra, poiché, in Tk, "finestra" e "widget" sono spesso usati in modo intercambiabile.
Le applicazioni Tk seguono una gerarchia di widget in cui un numero qualsiasi di widget può essere posizionato all'interno di un altro widget e quei widget all'interno di un altro widget, all'infinito. Il widget principale in un programma Tk è denominato widget di root e può essere creato creando una nuova istanza della classe TkRoot.
La maggior parte delle applicazioni basate su Tk segue lo stesso ciclo: crea i widget, inseriscili nell'interfaccia e, infine, associa gli eventi associati a ciascun widget a un metodo.
Sono disponibili tre gestori di geometria; luogo, griglia e pacchetto che sono responsabili del controllo delle dimensioni e della posizione di ciascuno dei widget nell'interfaccia.
Installazione
I collegamenti Ruby Tk sono distribuiti con Ruby ma Tk è un'installazione separata. Gli utenti Windows possono scaricare l'installazione di Tk con un solo clic da ActiveTcl di ActiveState .
Gli utenti Mac e Linux potrebbero non aver bisogno di installarlo perché c'è una grande possibilità che sia già installato insieme al sistema operativo, ma in caso contrario, puoi scaricare pacchetti precompilati o ottenere i sorgenti da Tcl Developer Xchange .
Semplice applicazione Tk
Una struttura tipica per i programmi Ruby / Tk è creare il file principale o root finestra (un'istanza di TkRoot), aggiungere widget ad essa per creare l'interfaccia utente, quindi avviare il ciclo di eventi principale chiamando Tk.mainloop.
Il tradizionale Hello, World! esempio per Ruby / Tk ha un aspetto simile a questo -
require 'tk'
root = TkRoot.new { title "Hello, World!" }
TkLabel.new(root) do
text 'Hello, World!'
pack { padx 15 ; pady 15; side 'left' }
end
Tk.mainloop
Qui, dopo aver caricato il modulo di estensione tk, creiamo un frame a livello di root utilizzando TkRoot.new . Quindi creiamo un widget TkLabel come figlio del frame radice, impostando diverse opzioni per l'etichetta. Infine, impacchettiamo il frame radice e accediamo al ciclo di eventi della GUI principale.
Se eseguissi questo script, produrrebbe il seguente risultato:
Classi di widget Ruby / Tk
C'è un elenco di varie classi Ruby / Tk, che possono essere utilizzate per creare una GUI desiderata utilizzando Ruby / Tk.
TkFrame Crea e manipola i widget frame.
TkButton Crea e manipola i widget dei pulsanti.
TkLabel Crea e manipola i widget etichetta.
TkEntry Crea e manipola i widget di ingresso.
TkCheckButton Crea e manipola i widget checkbutton.
TkRadioButton Crea e manipola i widget dei pulsanti di opzione .
TkListbox Crea e manipola i widget listbox.
TkComboBox Crea e manipola i widget listbox.
TkMenu Crea e manipola i widget del menu.
TkMenubutton Crea e manipola i widget dei pulsanti dei menu.
Tk.messageBox Crea e manipola una finestra di dialogo di messaggio.
TkScrollbar Crea e manipola i widget della barra di scorrimento.
TkCanvas Crea e manipola i widget canvas.
TkScale Crea e manipola i widget di scala.
TkText Crea e manipola widget di testo.
TkToplevel Crea e manipola widget di primo livello.
TkSpinbox Crea e manipola i widget Spinbox.
TkProgressBar Crea e manipola i widget della barra di avanzamento.
Finestra di dialogo Crea e manipola i widget della finestra di dialogo.
Tk :: Tile :: Notebook Visualizza diverse finestre in uno spazio limitato con la metafora del notebook.
Tk :: Tile :: Paned Visualizza un numero di sottofinestre, impilate verticalmente o orizzontalmente.
Tk :: Tile :: Separator Visualizza una barra di separazione orizzontale o verticale.
Caratteri, colori e immagini Ruby / Tk Comprensione dei caratteri, colori e immagini di Ruby / Tk
Opzioni di configurazione standard
Tutti i widget hanno una serie di diverse opzioni di configurazione, che generalmente controllano come vengono visualizzati o come si comportano. Le opzioni disponibili dipendono ovviamente dalla classe del widget.
Ecco un elenco di tutte le opzioni di configurazione standard, che potrebbero essere applicabili a qualsiasi widget Ruby / Tk.
Sr.No. | Opzioni e descrizione |
---|---|
1 | activebackground => Stringa Specifica il colore di sfondo da utilizzare quando si disegnano elementi attivi. Un elemento è attivo se il cursore del mouse è posizionato sull'elemento e premendo un pulsante del mouse si verificherà un'azione. Puoi utilizzare nomi di colore come "rosso", "blu", "rosa", "giallo" ecc. |
2 | activeborderwidth => Intero Specifica un valore non negativo che indica la larghezza del bordo 3D disegnato attorno agli elementi attivi. |
3 | activeforeground => Stringa Specifica il colore di primo piano da utilizzare quando si disegnano elementi attivi. |
4 | anchor => Stringa Specifica come le informazioni in un widget (ad es. Testo o bitmap) devono essere visualizzate nel widget. Deve essere uno dei valorin, ne, e, se, s, sw, w, nw, o center. Per esempio,nw significa visualizzare le informazioni in modo tale che il suo angolo in alto a sinistra si trovi nell'angolo in alto a sinistra del widget. |
5 | background or bg => Stringa Specifica il normale colore di sfondo da utilizzare durante la visualizzazione del widget. |
6 | bitmap => Bitmap Specifica una bitmap da visualizzare nel widget. Il modo esatto in cui viene visualizzata la bitmap può essere influenzato da altre opzioni come ancoraggio o giustificazione. |
7 | borderwidth or bd => Intero Specifica un valore non negativo che indica la larghezza del bordo 3-D da disegnare intorno all'esterno del widget. |
8 | compound => Stringa Specifica se il widget deve visualizzare contemporaneamente testo e bitmap / immagini e, in tal caso, dove deve essere posizionata la bitmap / immagine rispetto al testo. Deve essere uno dei valorinone, bottom, top, left, right, o center. |
9 | cursor => Stringa Specifica il cursore del mouse da utilizzare per il widget. I valori possibili potrebbero essere "watch", "arrow" ecc. |
10 | disabledforeground => Stringa Specifica il colore di primo piano da utilizzare quando si disegna un elemento disabilitato. |
11 | exportselection => Booleano Specifica se una selezione nel widget deve essere anche la selezione X. Il valore può avere uno qualsiasi deitrue, false, 0, 1, yes, o no. Se la selezione viene esportata, la selezione nel widget deseleziona la selezione X corrente, la selezione all'esterno del widget deseleziona qualsiasi selezione di widget e il widget risponderà alle richieste di recupero della selezione quando ha una selezione. |
12 | font => Stringa Specifica il carattere da utilizzare quando si disegna il testo all'interno del widget. |
13 | foreground or fg => Stringa Specifica il normale colore di primo piano da utilizzare durante la visualizzazione del widget. |
14 | highlightbackground => Stringa Specifica il colore da visualizzare nell'area di evidenziazione trasversale quando il widget non ha il focus di input. |
15 | highlightcolor => Stringa Specifica il colore da utilizzare per il rettangolo di evidenziazione trasversale che viene disegnato intorno al widget quando ha lo stato attivo per l'input. |
16 | highlightthickness => Intero Specifica un valore non negativo che indica la larghezza del rettangolo di evidenziazione da disegnare intorno all'esterno del widget quando ha lo stato attivo per l'input. |
17 | image => Immagine Specifica un'immagine da visualizzare nel widget, che deve essere stata creata con un'immagine create. In genere, se viene specificata l'opzione immagine, sovrascrive altre opzioni che specificano un valore bitmap o testuale da visualizzare nel widget; l'opzione immagine può essere reimpostata su una stringa vuota per riattivare una visualizzazione bitmap o di testo. |
18 | jump => Stringa Per i widget con un cursore che può essere trascinato per regolare un valore, come le barre di scorrimento e le scale, questa opzione determina quando vengono effettuate notifiche sulle modifiche del valore. Il valore dell'opzione deve essere un booleano. Se il valore è false, gli aggiornamenti vengono effettuati continuamente mentre il dispositivo di scorrimento viene trascinato. Se il valore è true, gli aggiornamenti vengono ritardati fino al rilascio del pulsante del mouse per terminare il trascinamento; a quel punto viene fatta un'unica notifica. |
19 | justify => Stringa Quando sono presenti più righe di testo visualizzate in un widget, questa opzione determina il modo in cui le righe si allineano l'una con l'altra. Deve essere uno dileft, center, o right. Left significa che i bordi di sinistra delle linee sono tutti allineati, center significa che i centri delle linee sono allineati e right significa che i bordi destri delle linee sono allineati. |
20 | offset => Stringa Specifica l'offset delle tessere (vedere anche tileopzione). Può avere due formati differentioffset x,y o offset side, dove può essere il lato n, ne, e, se, s, sw, w, nw, o center. |
21 | orient => Stringa Per i widget che possono essere disposti con un orientamento orizzontale o verticale, come le barre di scorrimento, questa opzione specifica quale orientamento deve essere utilizzato. Devono essere entrambihorizontal o vertical o un'abbreviazione di uno di questi. |
22 | padx => Intero Specifica un valore non negativo che indica la quantità di spazio extra da richiedere per il widget nella direzione X. |
23 | pady => Intero Specifica un valore non negativo che indica lo spazio aggiuntivo da richiedere per il widget nella direzione Y. |
24 | relief => Intero Specifica l'effetto 3-D desiderato per il widget. I valori accettabili sonoraised, sunken, flat, ridge, e groove. |
25 | repeatdelay => Intero Specifica il numero di millisecondi che un pulsante o un tasto deve essere tenuto premuto prima che inizi la ripetizione automatica. Utilizzato, ad esempio, sulle frecce su e giù nelle barre di scorrimento. |
26 | repeatinterval => Intero Usato insieme a repeatdelay: una volta iniziata la ripetizione automatica, questa opzione determina il numero di millisecondi tra le ripetizioni automatiche |
27 | selectbackground => Stringa Specifica il colore di sfondo da utilizzare durante la visualizzazione degli elementi selezionati. |
28 | selectborderwidth => Intero Specifica un valore non negativo che indica la larghezza del bordo 3D per disegnare intorno agli elementi selezionati. |
29 | selectforeground => Stringa Specifica il colore di primo piano da utilizzare durante la visualizzazione degli elementi selezionati. |
30 | setgrid => Booleano Specifica un valore booleano che determina se questo widget controlla la griglia di ridimensionamento per la sua finestra di primo livello. Questa opzione viene tipicamente utilizzata nei widget di testo, dove le informazioni nel widget hanno una dimensione naturale (la dimensione di un carattere) e ha senso che le dimensioni della finestra siano numeri interi di queste unità. |
31 | takefocus => Intero Fornisce le informazioni utilizzate quando si sposta il focus da una finestra all'altra tramite l'attraversamento della tastiera (ad esempio, Tab e Maiusc-Tab). Prima di impostare il focus su una finestra, gli script di attraversamento controllano innanzitutto se la finestra è visualizzabile (essa e tutti i suoi antenati sono mappati); in caso contrario, la finestra viene saltata. Un valore di 0 significa che questa finestra dovrebbe essere saltata completamente durante l'attraversamento della tastiera. 1 significa che questa finestra dovrebbe sempre ricevere il focus di input. |
32 | text => Stringa Specifica una stringa da visualizzare all'interno del widget. Il modo in cui la stringa viene visualizzata dipende dal particolare widget e può essere determinato da altre opzioni, comeanchor o justify. |
33 | textvariable => Variabile Specifica il nome di una variabile. Il valore della variabile è una stringa di testo da visualizzare all'interno del widget; se il valore della variabile cambia, il widget si aggiornerà automaticamente per riflettere il nuovo valore. Il modo in cui la stringa viene visualizzata nel widget dipende dal particolare widget e può essere determinato da altre opzioni, comeanchor o justify. |
34 | tile => Immagine Specifica l'immagine utilizzata per visualizzare il widget. Se l'immagine è una stringa vuota, viene visualizzato il colore di sfondo normale. |
35 | troughcolor => Stringa Specifica il colore da utilizzare per le aree di depressione rettangolari in widget quali barre di scorrimento e scale. |
36 | troughtile => Immagine Specifica l'immagine utilizzata per la visualizzazione nelle aree di depressione rettangolari in widget come barre di scorrimento e scale. |
37 | underline => Intero Specifica l'indice intero di un carattere da sottolineare nel widget. Questa opzione viene utilizzata dalle associazioni predefinite per implementare l'attraversamento della tastiera per i pulsanti di menu e le voci di menu. 0 corrisponde al primo carattere del testo visualizzato nel widget, 1 al carattere successivo e così via. |
38 | wraplength => Intero Per i widget che possono eseguire il ritorno a capo automatico, questa opzione specifica la lunghezza massima della riga. |
39 | xscrollcommand => funzione Specifica un callback utilizzato per comunicare con le barre di scorrimento orizzontali. |
40 | yscrollcommand => funzione Specifica un callback utilizzato per comunicare con le barre di scorrimento verticali. |
Gestione della geometria Ruby / Tk
La gestione della geometria si occupa del posizionamento di diversi widget secondo i requisiti. La gestione della geometria in Tk si basa sul concetto di widget master e slave.
Un master è un widget, tipicamente una finestra di primo livello o una cornice, che conterrà altri widget, chiamati slave. Puoi pensare a un gestore di geometrie come se prendesse il controllo del widget principale e decidesse cosa verrà visualizzato all'interno.
Il gestore della geometria chiederà a ciascun widget slave la sua dimensione naturale o quanto grande vorrebbe essere visualizzato idealmente. Quindi prende quelle informazioni e le combina con tutti i parametri forniti dal programma quando chiede al gestore della geometria di gestire quel particolare widget slave.
Ci sono tre gestori di geometria, luogo, griglia e pacchetto che sono responsabili del controllo delle dimensioni e della posizione di ciascuno dei widget nell'interfaccia.
griglia Geometry manager che dispone i widget in una griglia.
pack Geometry manager che avvolge i bordi della cavità.
place Manager Geometria per il posizionamento fisso o di fogli di gomma.
Gestione degli eventi Ruby / Tk
Ruby / Tk supporta il ciclo di eventi , che riceve gli eventi dal sistema operativo. Queste sono cose come la pressione dei pulsanti, le sequenze di tasti, il movimento del mouse, il ridimensionamento della finestra e così via.
Ruby / Tk si prende cura di gestire questo ciclo di eventi per te. Scoprirà a quale widget si applica l'evento (l'utente ha fatto clic su questo pulsante? Se è stato premuto un tasto, quale casella di testo aveva il focus?) E lo invierà di conseguenza. I singoli widget sanno come rispondere agli eventi, quindi ad esempio un pulsante potrebbe cambiare colore quando il mouse si sposta su di esso e tornare indietro quando il mouse esce.
A un livello superiore, Ruby / Tk richiama i callback nel tuo programma per indicare che qualcosa di significativo è accaduto a un widget. In entrambi i casi, puoi fornire un blocco di codice o un oggetto Ruby Proc che specifica come l'applicazione risponde all'evento o al callback.
Diamo uno sguardo a come utilizzare il metodo bind per associare eventi di sistema a finestre di base con le procedure Ruby che li gestiscono. La forma più semplice di bind prende come input una stringa che indica il nome dell'evento e un blocco di codice che Tk usa per gestire l'evento.
Ad esempio, per catturare l' evento ButtonRelease per il primo pulsante del mouse su un widget, dovresti scrivere:
someWidget.bind('ButtonRelease-1') {
....code block to handle this event...
}
Il nome di un evento può includere modificatori e dettagli aggiuntivi. Un modificatore è una stringa come Shift , Control o Alt , che indica che è stato premuto uno dei tasti modificatori.
Quindi, ad esempio, per catturare l'evento che viene generato quando l'utente tiene premuto il tasto Ctrl e fa clic con il pulsante destro del mouse.
someWidget.bind('Control-ButtonPress-3', proc { puts "Ouch!" })
Molti widget Ruby / Tk possono attivare callback quando l'utente li attiva e puoi utilizzare il comando callback per specificare che un determinato blocco di codice o procedura viene invocato quando ciò accade. Come visto in precedenza, puoi specificare la procedura di callback del comando quando crei il widget:
helpButton = TkButton.new(buttonFrame) {
text "Help"
command proc { showHelp }
}
Oppure puoi assegnarlo in un secondo momento, utilizzando il metodo di comando del widget :
helpButton.command proc { showHelp }
Poiché il metodo di comando accetta procedure o blocchi di codice, è anche possibile scrivere l'esempio di codice precedente come:
helpButton = TkButton.new(buttonFrame) {
text "Help"
command { showHelp }
}
Sr.No. | Tag e descrizione dell'evento |
---|---|
1 | "1" (one) Pulsante sinistro del mouse cliccato. |
2 | "ButtonPress-1" Pulsante sinistro del mouse cliccato. |
3 | "Enter" Mouse spostato all'interno. |
4 | "Leave" Mouse spostato all'esterno. |
5 | "Double-1" Doppio clic. |
6 | "B3-Motion" Trascina il pulsante destro da una posizione all'altra. |
7 | Control-ButtonPress-3 Il pulsante destro viene premuto insieme al tasto Ctrl . |
8 | Alt-ButtonPress-1 Il pulsante Lascia viene premuto insieme al tasto Alt . |
Il metodo configure
Il metodo configure può essere utilizzato per impostare e recuperare qualsiasi valore di configurazione del widget. Ad esempio, per modificare la larghezza di un pulsante è possibile chiamare il metodo di configurazione in qualsiasi momento come segue:
require "tk"
button = TkButton.new {
text 'Hello World!'
pack
}
button.configure('activebackground', 'blue')
Tk.mainloop
Per ottenere il valore per un widget corrente, forniscilo senza un valore come segue:
color = button.configure('activebackground')
Puoi anche chiamare configure senza alcuna opzione, che ti darà un elenco di tutte le opzioni e dei loro valori.
Il metodo cget
Per recuperare semplicemente il valore di un'opzione, configure restituisce più informazioni di quelle che generalmente desideri. Il metodo cget restituisce solo il valore corrente.
color = button.cget('activebackground')
Ruby / LDAP è una libreria di estensioni per Ruby. Fornisce l'interfaccia ad alcune librerie LDAP come OpenLDAP, UMich LDAP, Netscape SDK, ActiveDirectory.
L'API comune per lo sviluppo di applicazioni è descritta in RFC1823 ed è supportata da Ruby / LDAP.
Installazione di Ruby / LDAP
Puoi scaricare e installare un pacchetto Ruby / LDAP completo da SOURCEFORGE.NET .
Prima di installare Ruby / LDAP, assicurati di avere i seguenti componenti:
- Ruby 1.8.x (almeno 1.8.2 se vuoi usare ldap / control).
- OpenLDAP, Netscape SDK, Windows 2003 o Windows XP.
Ora puoi usare il metodo di installazione standard di Ruby. Prima di iniziare, se desideri vedere le opzioni disponibili per extconf.rb, eseguilo con l'opzione '--help'.
$ ruby extconf.rb [--with-openldap1|--with-openldap2| \
--with-netscape|--with-wldap32]
$ make $ make install
NOTE- Se stai creando il software su Windows, potresti dover usare nmake invece di make .
Stabilire una connessione LDAP
Questo è un processo in due fasi:
Passaggio 1: creare un oggetto di connessione
Di seguito è riportata la sintassi per creare una connessione a una directory LDAP.
LDAP::Conn.new(host = 'localhost', port = LDAP_PORT)
host- Questo è l'ID host che esegue la directory LDAP. Lo prenderemo come localhost .
port- Questa è la porta utilizzata per il servizio LDAP. Le porte LDAP standard sono 636 e 389. Assicurati che la porta sia utilizzata sul tuo server altrimenti puoi usare LDAP :: LDAP_PORT.
Questa chiamata restituisce una nuova connessione LDAP :: Conn al server, host , sulla porta .
Passaggio 2: rilegatura
Qui è dove di solito specifichiamo il nome utente e la password che useremo per il resto della sessione.
Di seguito è riportata la sintassi per associare una connessione LDAP, utilizzando il DN, dn, la credenziale, pwde il metodo bind, method -
conn.bind(dn = nil, password = nil, method = LDAP::LDAP_AUTH_SIMPLE)do
....
end
È possibile utilizzare lo stesso metodo senza un blocco di codice. In questo caso, sarà necessario svincolare la connessione in modo esplicito come segue:
conn.bind(dn = nil, password = nil, method = LDAP::LDAP_AUTH_SIMPLE)
....
conn.unbind
Se viene fornito un blocco di codice, self viene ceduto al blocco.
Ora possiamo eseguire operazioni di ricerca, aggiunta, modifica o eliminazione all'interno del blocco del metodo bind (tra bind e unbind), a patto di disporre delle autorizzazioni appropriate.
Example
Supponendo che stiamo lavorando su un server locale, mettiamo insieme le cose con host, dominio, ID utente e password appropriati, ecc.
#/usr/bin/ruby -w
require 'ldap'
$HOST = 'localhost' $PORT = LDAP::LDAP_PORT
$SSLPORT = LDAP::LDAPS_PORT conn = LDAP::Conn.new($HOST, $PORT)
conn.bind('cn = root, dc = localhost, dc = localdomain','secret')
....
conn.unbind
Aggiunta di una voce LDAP
L'aggiunta di una voce LDPA è un processo in due fasi:
Passaggio 1: creazione dell'oggetto LDAP :: Mod
Abbiamo bisogno del passaggio dell'oggetto LDAP :: Mod al metodo conn.add per creare una voce. Ecco una semplice sintassi per creare LDAP :: oggetto Mod -
Mod.new(mod_type, attr, vals)
mod_type - Una o più opzioni LDAP_MOD_ADD, LDAP_MOD_REPLACE o LDAP_MOD_DELETE.
attr - dovrebbe essere il nome dell'attributo su cui operare.
vals- è un array di valori relativi ad attr . Se vals contiene dati binari, mod_type dovrebbe essere logicamente OR'ed (|) con LDAP_MOD_BVALUES.
Questa chiamata restituisce un oggetto LDAP :: Mod , che può essere passato ai metodi nella classe LDAP :: Conn, come Conn # add, Conn # add_ext, Conn # modify e Conn # modify_ext.
Passaggio 2: chiamata al metodo conn.add
Una volta che siamo pronti con l' oggetto LDAP :: Mod , possiamo chiamare il metodo conn.add per creare una voce. Ecco una sintassi per chiamare questo metodo:
conn.add(dn, attrs)
Questo metodo aggiunge una voce con DN, dn e attributi attrs . In questo caso, attrs dovrebbe essere un array di oggetti LDAP :: Mod o un hash di coppie di array attributo / valore.
Example
Ecco un esempio completo, che creerà due voci di directory:
#/usr/bin/ruby -w
require 'ldap'
$HOST = 'localhost'
$PORT = LDAP::LDAP_PORT $SSLPORT = LDAP::LDAPS_PORT
conn = LDAP::Conn.new($HOST, $PORT)
conn.bind('cn = root, dc = localhost, dc = localdomain','secret')
conn.perror("bind")
entry1 = [
LDAP.mod(LDAP::LDAP_MOD_ADD,'objectclass',['top','domain']),
LDAP.mod(LDAP::LDAP_MOD_ADD,'o',['TTSKY.NET']),
LDAP.mod(LDAP::LDAP_MOD_ADD,'dc',['localhost']),
]
entry2 = [
LDAP.mod(LDAP::LDAP_MOD_ADD,'objectclass',['top','person']),
LDAP.mod(LDAP::LDAP_MOD_ADD, 'cn', ['Zara Ali']),
LDAP.mod(LDAP::LDAP_MOD_ADD | LDAP::LDAP_MOD_BVALUES, 'sn',
['ttate','ALI', "zero\000zero"]),
]
begin
conn.add("dc = localhost, dc = localdomain", entry1)
conn.add("cn = Zara Ali, dc = localhost, dc = localdomain", entry2)
rescue LDAP::ResultError
conn.perror("add")
exit
end
conn.perror("add")
conn.unbind
Modifica di una voce LDAP
La modifica di una voce è simile all'aggiunta di una. Basta chiamare il metodo di modifica invece di aggiungere con gli attributi da modificare. Ecco una semplice sintassi del metodo di modifica .
conn.modify(dn, mods)
Questo metodo modifica una voce con DN, dn e attributi, mod . Qui, le mod dovrebbero essere un array di oggetti LDAP :: Mod o un hash di coppie di array attributo / valore.
Esempio
Per modificare il cognome della voce, che abbiamo aggiunto nella sezione precedente, scriveremmo -
#/usr/bin/ruby -w
require 'ldap'
$HOST = 'localhost' $PORT = LDAP::LDAP_PORT
$SSLPORT = LDAP::LDAPS_PORT conn = LDAP::Conn.new($HOST, $PORT)
conn.bind('cn = root, dc = localhost, dc = localdomain','secret')
conn.perror("bind")
entry1 = [
LDAP.mod(LDAP::LDAP_MOD_REPLACE, 'sn', ['Mohtashim']),
]
begin
conn.modify("cn = Zara Ali, dc = localhost, dc = localdomain", entry1)
rescue LDAP::ResultError
conn.perror("modify")
exit
end
conn.perror("modify")
conn.unbind
Eliminazione di una voce LDAP
Per eliminare una voce, chiamare il metodo di eliminazione con il nome distinto come parametro. Ecco una semplice sintassi del metodo di eliminazione .
conn.delete(dn)
Questo metodo elimina una voce con DN, dn .
Esempio
Per eliminare la voce di Zara Mohtashim , che abbiamo aggiunto nella sezione precedente, scriveremmo:
#/usr/bin/ruby -w
require 'ldap'
$HOST = 'localhost'
$PORT = LDAP::LDAP_PORT $SSLPORT = LDAP::LDAPS_PORT
conn = LDAP::Conn.new($HOST, $PORT)
conn.bind('cn = root, dc = localhost, dc = localdomain','secret')
conn.perror("bind")
begin
conn.delete("cn = Zara-Mohtashim, dc = localhost, dc = localdomain")
rescue LDAP::ResultError
conn.perror("delete")
exit
end
conn.perror("delete")
conn.unbind
Modifica del nome distinto
Non è possibile modificare il nome distinto di una voce con il metodo di modifica . Usa invece il metodo modrdn . Ecco la semplice sintassi del metodo modrdn :
conn.modrdn(dn, new_rdn, delete_old_rdn)
Questo metodo modifica l'RDN della voce con DN, dn , dandogli il nuovo RDN, new_rdn . Se delete_old_rdn è true , il vecchio valore RDN verrà eliminato dalla voce.
Esempio
Supponiamo di avere la seguente voce:
dn: cn = Zara Ali,dc = localhost,dc = localdomain
cn: Zara Ali
sn: Ali
objectclass: person
Quindi, possiamo modificare il suo nome distinto con il seguente codice:
#/usr/bin/ruby -w
require 'ldap'
$HOST = 'localhost' $PORT = LDAP::LDAP_PORT
$SSLPORT = LDAP::LDAPS_PORT conn = LDAP::Conn.new($HOST, $PORT)
conn.bind('cn = root, dc = localhost, dc = localdomain','secret')
conn.perror("bind")
begin
conn.modrdn("cn = Zara Ali, dc = localhost, dc = localdomain", "cn = Zara Mohtashim", true)
rescue LDAP::ResultError
conn.perror("modrdn")
exit
end
conn.perror("modrdn")
conn.unbind
Esecuzione di una ricerca
Per eseguire una ricerca su una directory LDAP, utilizzare il metodo di ricerca con una delle tre diverse modalità di ricerca:
LDAP_SCOPE_BASEM - Cerca solo il nodo base.
LDAP_SCOPE_ONELEVEL - Cerca tutti i figli del nodo di base.
LDAP_SCOPE_SUBTREE - Cerca in tutta la sottostruttura incluso il nodo di base.
Esempio
Qui, cercheremo l'intero sottoalbero della voce dc = localhost, dc = localdomain per oggetti persona -
#/usr/bin/ruby -w
require 'ldap'
$HOST = 'localhost'
$PORT = LDAP::LDAP_PORT $SSLPORT = LDAP::LDAPS_PORT
base = 'dc = localhost,dc = localdomain'
scope = LDAP::LDAP_SCOPE_SUBTREE
filter = '(objectclass = person)'
attrs = ['sn', 'cn']
conn = LDAP::Conn.new($HOST, $PORT)
conn.bind('cn = root, dc = localhost, dc = localdomain','secret')
conn.perror("bind")
begin
conn.search(base, scope, filter, attrs) { |entry|
# print distinguished name
p entry.dn
# print all attribute names
p entry.attrs
# print values of attribute 'sn'
p entry.vals('sn')
# print entry as Hash
p entry.to_hash
}
rescue LDAP::ResultError
conn.perror("search")
exit
end
conn.perror("search")
conn.unbind
Ciò richiama il blocco di codice specificato per ciascuna voce corrispondente in cui la voce LDAP è rappresentata da un'istanza della classe LDAP :: Entry. Con l'ultimo parametro di ricerca, puoi specificare gli attributi a cui sei interessato, omettendo tutti gli altri. Se qui si passa nil, tutti gli attributi vengono restituiti come "SELECT *" nei database relazionali.
Il metodo dn (alias per get_dn) della classe LDAP :: Entry restituisce il nome distinto della voce e con il metodo to_hash è possibile ottenere una rappresentazione hash dei suoi attributi (incluso il nome distinto). Per ottenere un elenco degli attributi di una voce, utilizzare il metodo attrs (alias per get_attributes). Inoltre, per ottenere l'elenco dei valori di uno specifico attributo, utilizzare il metodo vals (alias per get_values).
Gestione degli errori
Ruby / LDAP definisce due diverse classi di eccezioni:
In caso di errore, i metodi new, bind o unbind sollevano un'eccezione LDAP :: Error.
In caso di aggiunta, modifica, eliminazione o ricerca in una directory LDAP solleva un'eccezione LDAP :: ResultError.
Ulteriori letture
Per i dettagli completi sui metodi LDAP, fare riferimento alla documentazione standard per la documentazione LDAP .
I programmi tradizionali hanno un singolo thread di esecuzione le istruzioni o le istruzioni che compongono il programma vengono eseguite in sequenza fino al termine del programma.
Un programma multithread ha più di un thread di esecuzione. All'interno di ogni thread, le istruzioni vengono eseguite in sequenza, ma i thread stessi possono essere eseguiti in parallelo su una CPU multicore, ad esempio. Spesso su una singola macchina CPU, più thread non vengono effettivamente eseguiti in parallelo, ma il parallelismo viene simulato intercalando l'esecuzione dei thread.
Ruby semplifica la scrittura di programmi multi-thread con la classe Thread . I thread Ruby sono un modo leggero ed efficiente per ottenere la concorrenza nel codice.
Creazione di thread Ruby
Per iniziare un nuovo thread, associa semplicemente un blocco a una chiamata a Thread.new . Verrà creato un nuovo thread per eseguire il codice nel blocco e il thread originale tornerà immediatamente da Thread.new e riprenderà l'esecuzione con l'istruzione successiva -
# Thread #1 is running here
Thread.new {
# Thread #2 runs this code
}
# Thread #1 runs this code
Esempio
Ecco un esempio, che mostra come possiamo usare il programma Ruby multi-thread.
#!/usr/bin/ruby
def func1
i = 0
while i<=2
puts "func1 at: #{Time.now}"
sleep(2)
i = i+1
end
end
def func2
j = 0
while j<=2
puts "func2 at: #{Time.now}"
sleep(1)
j = j+1
end
end
puts "Started At #{Time.now}"
t1 = Thread.new{func1()}
t2 = Thread.new{func2()}
t1.join
t2.join
puts "End at #{Time.now}"
Questo produrrà il seguente risultato:
Started At Wed May 14 08:21:54 -0700 2008
func1 at: Wed May 14 08:21:54 -0700 2008
func2 at: Wed May 14 08:21:54 -0700 2008
func2 at: Wed May 14 08:21:55 -0700 2008
func1 at: Wed May 14 08:21:56 -0700 2008
func2 at: Wed May 14 08:21:56 -0700 2008
func1 at: Wed May 14 08:21:58 -0700 2008
End at Wed May 14 08:22:00 -0700 2008
Ciclo di vita del thread
Vengono creati nuovi thread con Thread.new . Puoi anche utilizzare i sinonimi Thread.start e Thread.fork .
Non è necessario avviare un thread dopo averlo creato, inizia a funzionare automaticamente quando le risorse della CPU diventano disponibili.
La classe Thread definisce una serie di metodi per interrogare e manipolare il thread mentre è in esecuzione. Un thread esegue il codice nel blocco associato alla chiamata a Thread.new e quindi interrompe l'esecuzione.
Il valore dell'ultima espressione in quel blocco è il valore del thread e può essere ottenuto chiamando il metodo value dell'oggetto Thread. Se il thread è stato eseguito fino al completamento, il valore restituisce immediatamente il valore del thread. In caso contrario, il metodo value si blocca e non ritorna fino al completamento del thread.
Il metodo di classe Thread.current restituisce l'oggetto Thread che rappresenta il thread corrente. Ciò consente ai thread di manipolare se stessi. Il metodo di classe Thread.main restituisce l'oggetto Thread che rappresenta il thread principale. Questo è il thread di esecuzione iniziale che è iniziato quando è stato avviato il programma Ruby.
È possibile attendere il completamento di un thread particolare chiamando il metodo Thread.join di quel thread . Il thread chiamante si bloccherà fino al termine del thread specificato.
Thread ed eccezioni
Se viene sollevata un'eccezione nel thread principale e non viene gestita da nessuna parte, l'interprete di Ruby stampa un messaggio ed esce. Nei thread, diversi dal thread principale, le eccezioni non gestite causano l'interruzione dell'esecuzione del thread.
Se un thread t esce a causa di un'eccezione non gestita e di un altro thread schiama t.join o t.value, quindi l'eccezione che si è verificata int è sollevato nel thread s.
Se Thread.abort_on_exception è false , la condizione predefinita, un'eccezione non gestita, uccide semplicemente il thread corrente e tutto il resto continua a essere eseguito.
Se desideri che un'eccezione non gestita in qualsiasi thread provochi l'uscita dell'interprete, imposta il metodo di classe Thread.abort_on_exception su true .
t = Thread.new { ... }
t.abort_on_exception = true
Variabili di thread
Un thread può normalmente accedere a tutte le variabili che sono nell'ambito quando il thread viene creato. Le variabili locali al blocco di un thread sono locali al thread e non sono condivise.
La classe Thread presenta una funzione speciale che consente la creazione e l'accesso alle variabili locali del thread in base al nome. Trattate semplicemente l'oggetto thread come se fosse un hash, scrivendo sugli elementi usando [] = e leggendoli di nuovo usando [].
In questo esempio, ogni thread registra il valore corrente della variabile count in una variabile threadlocal con la chiave mycount .
#!/usr/bin/ruby
count = 0
arr = []
10.times do |i|
arr[i] = Thread.new {
sleep(rand(0)/10.0)
Thread.current["mycount"] = count
count += 1
}
end
arr.each {|t| t.join; print t["mycount"], ", " }
puts "count = #{count}"
Questo produce il seguente risultato:
8, 0, 3, 7, 2, 1, 6, 5, 4, 9, count = 10
Il thread principale attende che i thread secondari finiscano e quindi stampa il valore del conteggio acquisito da ciascuno.
Priorità thread
Il primo fattore che influisce sulla pianificazione del thread è la priorità del thread: i thread ad alta priorità vengono pianificati prima dei thread a bassa priorità. Più precisamente, un thread otterrà il tempo della CPU solo se non ci sono thread con priorità più alta in attesa di essere eseguiti.
Puoi impostare e interrogare la priorità di un oggetto Ruby Thread con priorità = e priorità . Un thread appena creato inizia con la stessa priorità del thread che lo ha creato. Il thread principale inizia con priorità 0.
Non è possibile impostare la priorità di un thread prima che inizi l'esecuzione. Un thread può, tuttavia, aumentare o diminuire la propria priorità come prima azione che esegue.
Esclusione thread
Se due thread condividono l'accesso agli stessi dati e almeno uno dei thread modifica tali dati, è necessario prestare particolare attenzione per garantire che nessun thread possa mai vedere i dati in uno stato incoerente. Questa è chiamata esclusione dei thread .
Mutexè una classe che implementa un semplice blocco del semaforo per l'accesso mutuamente esclusivo ad alcune risorse condivise. Cioè, solo un thread può mantenere il blocco in un dato momento. Altri thread possono scegliere di attendere in linea affinché il blocco diventi disponibile, o possono semplicemente scegliere di ricevere un errore immediato che indica che il blocco non è disponibile.
Mettendo tutti gli accessi ai dati condivisi sotto il controllo di un mutex , garantiamo coerenza e funzionamento atomico. Proviamo a fare degli esempi, il primo senza mutax e il secondo con mutax -
Esempio senza Mutax
#!/usr/bin/ruby
require 'thread'
count1 = count2 = 0
difference = 0
counter = Thread.new do
loop do
count1 += 1
count2 += 1
end
end
spy = Thread.new do
loop do
difference += (count1 - count2).abs
end
end
sleep 1
puts "count1 : #{count1}"
puts "count2 : #{count2}"
puts "difference : #{difference}"
Questo produrrà il seguente risultato:
count1 : 1583766
count2 : 1583766
difference : 0
#!/usr/bin/ruby
require 'thread'
mutex = Mutex.new
count1 = count2 = 0
difference = 0
counter = Thread.new do
loop do
mutex.synchronize do
count1 += 1
count2 += 1
end
end
end
spy = Thread.new do
loop do
mutex.synchronize do
difference += (count1 - count2).abs
end
end
end
sleep 1
mutex.lock
puts "count1 : #{count1}"
puts "count2 : #{count2}"
puts "difference : #{difference}"
Questo produrrà il seguente risultato:
count1 : 696591
count2 : 696591
difference : 0
Gestione del deadlock
Quando iniziamo a utilizzare oggetti Mutex per l'esclusione dei thread, dobbiamo stare attenti a evitare deadlock . Deadlock è la condizione che si verifica quando tutti i thread sono in attesa di acquisire una risorsa contenuta in un altro thread. Poiché tutti i thread sono bloccati, non possono rilasciare i blocchi che trattengono. E poiché non possono rilasciare i blocchi, nessun altro thread può acquisire quei blocchi.
È qui che entrano in gioco le variabili di condizione . Una variabile di condizione è semplicemente un semaforo associato a una risorsa e viene utilizzato all'interno della protezione di un particolare mutex . Quando hai bisogno di una risorsa non disponibile, aspetti una variabile di condizione. Quell'azione rilascia il blocco sul mutex corrispondente . Quando un altro thread segnala che la risorsa è disponibile, il thread originale esce dall'attesa e contemporaneamente riguadagna il blocco nell'area critica.
Esempio
#!/usr/bin/ruby
require 'thread'
mutex = Mutex.new
cv = ConditionVariable.new
a = Thread.new {
mutex.synchronize {
puts "A: I have critical section, but will wait for cv"
cv.wait(mutex)
puts "A: I have critical section again! I rule!"
}
}
puts "(Later, back at the ranch...)"
b = Thread.new {
mutex.synchronize {
puts "B: Now I am critical, but am done with cv"
cv.signal
puts "B: I am still critical, finishing up"
}
}
a.join
b.join
Questo produrrà il seguente risultato:
A: I have critical section, but will wait for cv
(Later, back at the ranch...)
B: Now I am critical, but am done with cv
B: I am still critical, finishing up
A: I have critical section again! I rule!
Stati thread
Esistono cinque possibili valori di ritorno corrispondenti ai cinque stati possibili, come mostrato nella tabella seguente. Il metodo status restituisce lo stato del thread.
Stato del thread | Valore di ritorno |
---|---|
Runnable | correre |
Dormire | Dormire |
Interruzione | abortire |
Terminato normalmente | falso |
Terminato con eccezione | zero |
Metodi di classe di thread
I seguenti metodi sono forniti dalla classe Thread e sono applicabili a tutti i thread disponibili nel programma. Questi metodi verranno chiamati utilizzando il nome della classe Thread come segue:
Thread.abort_on_exception = true
Sr.No. | Metodi e descrizione |
---|---|
1 | Thread.abort_on_exception Restituisce lo stato dell'interruzione globale in condizione di eccezione . L'impostazione predefinita è false . Quando impostato su true , causerà l'interruzione di tutti i thread (il processo uscirà da (0)) se viene sollevata un'eccezione in qualsiasi thread |
2 | Thread.abort_on_exception= Quando è impostato su true , tutti i thread verranno interrotti se viene sollevata un'eccezione. Restituisce il nuovo stato. |
3 | Thread.critical Restituisce lo stato della condizione critica del thread globale . |
4 | Thread.critical= Imposta lo stato della condizione critica del thread globale e lo restituisce. Se impostato su true , impedisce la pianificazione di qualsiasi thread esistente. Non blocca la creazione e l'esecuzione di nuovi thread. Alcune operazioni di thread (come l'arresto o l'uccisione di un thread, la sospensione nel thread corrente e la generazione di un'eccezione) possono causare la pianificazione di un thread anche quando si trova in una sezione critica. |
5 | Thread.current Restituisce il thread attualmente in esecuzione. |
6 | Thread.exit Termina il thread attualmente in esecuzione e pianifica l'esecuzione di un altro thread. Se questo thread è già contrassegnato per essere terminato, exit restituisce il thread. Se questo è il thread principale o l'ultimo thread, uscire dal processo. |
7 | Thread.fork { block } Sinonimo di Thread.new. |
8 | Thread.kill( aThread ) Fa sì che la data un thread per uscire |
9 | Thread.list Restituisce un array di oggetti Thread per tutti i thread che possono essere eseguiti o arrestati. Filo. |
10 | Thread.main Restituisce il thread principale per il processo. |
11 | Thread.new( [ arg ]* ) {| args | block } Crea un nuovo thread per eseguire le istruzioni fornite nel blocco e inizia a eseguirlo. Tutti gli argomenti passati a Thread.new vengono passati al blocco. |
12 | Thread.pass Richiama lo scheduler del thread per passare l'esecuzione a un altro thread. |
13 | Thread.start( [ args ]* ) {| args | block } Fondamentalmente lo stesso di Thread.new . Tuttavia, se la classe Thread è una sottoclasse, la chiamata di start in quella sottoclasse non richiamerà il metodo di inizializzazione della sottoclasse . |
14 | Thread.stop Arresta l'esecuzione del thread corrente, mettendolo in uno stato di sospensione e pianifica l'esecuzione di un altro thread. Reimposta la condizione critica su false. |
Metodi di istanza del thread
Questi metodi sono applicabili a un'istanza di un thread. Questi metodi verranno chiamati utilizzando un'istanza di un thread come segue:
#!/usr/bin/ruby
thr = Thread.new do # Calling a class method new
puts "In second thread"
raise "Raise exception"
end
thr.join # Calling an instance method join
Sr.No. | Metodi e descrizione |
---|---|
1 | thr[ aSymbol ] Attributo di riferimento - Restituisce il valore di una variabile thread-local, utilizzando un simbolo o un aSymbol nome. Se la variabile specificata non esiste, restituisce nil . |
2 | thr[ aSymbol ] = Attributo Assignment - Imposta o crea il valore di una variabile locale del thread, utilizzando un simbolo o una stringa. |
3 | thr.abort_on_exception Restituisce lo stato di interruzione in condizione di eccezione per thr . L'impostazione predefinita è false . |
4 | thr.abort_on_exception= Quando è impostato su true , causa l'interruzione di tutti i thread (incluso il programma principale) se viene sollevata un'eccezione in thr . Il processo uscirà effettivamente (0) . |
5 | thr.alive? Restituisce vero se thr è in esecuzione o in sospensione. |
6 | thr.exit Termina thr e pianifica l'esecuzione di un altro thread. Se questo thread è già contrassegnato per essere terminato, exit restituisce il thread . Se questo è il thread principale o l'ultimo thread, esce dal processo. |
7 | thr.join Il thread chiamante sospenderà l'esecuzione ed eseguirà thr . Non tornerà fino thr uscite. Qualsiasi thread non unito verrà terminato quando il programma principale viene chiuso. |
8 | thr.key? Restituisce vero se la stringa (o il simbolo) data esiste come variabile locale del thread. |
9 | thr.kill Sinonimo di Thread.exit . |
10 | thr.priority Restituisce la priorità di thr . L'impostazione predefinita è zero; i thread con priorità più alta verranno eseguiti prima dei thread con priorità più bassa. |
11 | thr.priority= Imposta la priorità di thr su un numero intero. I thread con priorità più alta verranno eseguiti prima dei thread con priorità più bassa. |
12 | thr.raise( anException ) Genera un'eccezione da thr . Il chiamante non deve essere thr . |
13 | thr.run Si sveglia THR , che lo rende idoneo per la pianificazione. Se non in una sezione critica, richiama lo scheduler. |
14 | thr.safe_level Restituisce il livello di sicurezza in vigore per thr . |
15 | thr.status Restituisce lo stato di thr : sleep se thr è in sospensione o in attesa su I / O, run se thr è in esecuzione, false se thr è terminato normalmente e nil se thr è terminato con un'eccezione. |
16 | thr.stop? Restituisce vero se thr è morto o addormentato. |
17 | thr.value Attende il completamento di thr tramite Thread.join e restituisce il suo valore. |
18 | thr.wakeup Marks thr ammissibili per la pianificazione, si può ancora rimanere bloccato I / O, comunque. |
Poiché il modulo Kernel è incluso dalla classe Object , i suoi metodi sono disponibili ovunque nel programma Ruby. Possono essere chiamati senza ricevitore (modulo funzionale). Pertanto, sono spesso chiamate funzioni.
Sr.No. | Metodi e descrizione |
---|---|
1 | abort Termina il programma. Se viene sollevata un'eccezione (cioè, $! Non è nullo), viene visualizzato il suo messaggio di errore. |
2 | Array( obj) Restituisce obj dopo averlo convertito in un array utilizzando to_ary o to_a. |
3 | at_exit {...} Registra un blocco da eseguire quando il programma esce. Simile all'istruzione END, ma l'istruzione END registra il blocco solo una volta. |
4 | autoload( classname, file) Registra un nome classe di classe da caricare dal file la prima volta che viene utilizzato. classname può essere una stringa o un simbolo. |
5 | binding Restituisce la variabile corrente e le associazioni del metodo. L' oggetto Binding restituito può essere passato al metodo eval come secondo argomento. |
6 | block_given? Restituisce vero se il metodo è stato chiamato con un blocco . |
7 | callcc {| c|...} Passa un oggetto Continuation c al blocco ed esegue il blocco. callcc può essere utilizzato per l'uscita globale o per la costruzione del ciclo. |
8 | caller([ n]) Restituisce lo stack di esecuzione corrente in un array di stringhe nel file del modulo : riga . Se viene specificato n, restituisce le voci dello stack dall'ennesimo livello in giù. |
9 | catch( tag) {...} Cattura un'uscita non locale da un lancio chiamato durante l'esecuzione del suo blocco. |
10 | chomp([ rs = $/]) Restituisce il valore della variabile $_ with the ending newline removed, assigning the result back to $_. Il valore della stringa di nuova riga può essere specificato con rs. |
11 | chomp!([ rs = $/]) Rimuove la nuova riga da $ _, modificando la stringa in posizione. |
12 | chop Restituisce il valore di $_ with its last character (one byte) removed, assigning the result back to $_. |
13 | chop! Rimuove l'ultimo carattere da $ _, modificando la stringa in posizione. |
14 | eval( str[, scope[, file, line]]) Esegue str come codice Ruby. Il vincolo in cui eseguire la valutazione può essere specificato con scopo . Il nome del file e il numero di riga del codice da compilare possono essere specificati utilizzando file e riga. |
15 | exec( cmd[, arg...]) Sostituisce il processo corrente eseguendo il comando cmd . Se vengono specificati più argomenti, il comando viene eseguito senza espansione della shell. |
16 | exit([ result = 0]) Esce dal programma, restituendo il risultato come codice di stato. |
17 | exit!([ result = 0]) Uccide il programma ignorando la gestione delle uscite come garantire , ecc. |
18 | fail(...) Vedi raise (...) |
19 | Float( obj) Restituisce obj dopo averlo convertito in un float. Gli oggetti numerici vengono convertiti direttamente; nil viene convertito in 0,0; le stringhe vengono convertite considerando 0x, 0b radix prefix. Il resto viene convertito utilizzando obj.to_f. |
20 | fork fork {...} Crea un processo figlio. nil viene restituito nel processo figlio e l'ID (intero) del processo figlio viene restituito nel processo genitore. Se viene specificato un blocco, viene eseguito nel processo figlio. |
21 | format( fmt[, arg...]) Vedi sprintf. |
22 | gets([ rs = $/]) Legge il nome del file specificato nella riga di comando o una riga dallo standard input. La stringa del separatore di record può essere specificata esplicitamente con rs. |
23 | global_variables Restituisce un array di nomi di variabili globali. |
24 | gsub( x, y) gsub( x) {...} Sostituisce tutte le stringhe che corrispondono a x in $_ with y. If a block is specified, matched strings are replaced with the result of the block. The modified result is assigned to $_. |
25 | gsub!( x, y) gsub!( x) {...} Esegue la stessa sostituzione di gsub, tranne per il fatto che la stringa viene modificata in posizione. |
26 | Integer( obj) Restituisce obj dopo averlo convertito in un numero intero. Gli oggetti numerici vengono convertiti direttamente; nil viene convertito in 0; le stringhe vengono convertite considerando 0x, 0b radix prefix. Il resto viene convertito utilizzando obj.to_i. |
27 | lambda {| x|...} proc {| x|...} lambda proc Converte un blocco in un oggetto Proc . Se non viene specificato alcun blocco, viene convertito il blocco associato al metodo chiamante. |
28 | load( file[, private = false]) Carica un programma Ruby da file . A differenza di require , non carica le librerie di estensioni. Se private è vero , il programma viene caricato in un modulo anonimo, proteggendo così lo spazio dei nomi del programma chiamante. |
29 | local_variables Restituisce un array di nomi di variabili locali. |
30 | loop {...} Ripete un blocco di codice. |
31 | open( path[, mode = "r"]) open( path[, mode = "r"]) {| f|...} Apre un file . Se viene specificato un blocco, il blocco viene eseguito con il flusso aperto passato come argomento. Il file viene chiuso automaticamente quando il blocco esce. Se il percorso inizia con una barra verticale |, la seguente stringa viene eseguita come comando e viene restituito il flusso associato a quel processo. |
32 | p( obj) Visualizza obj usando il suo metodo inspect (spesso usato per il debug). |
33 | print([ arg...]) Stampa arg su $ defout . Se non vengono specificati argomenti, viene stampato il valore di $ _. |
34 | printf( fmt[, arg...]) Formatta arg secondo fmt usando sprintf e stampa il risultato in $ defout . Per le specifiche di formattazione, vedere sprintf per i dettagli. |
35 | proc {| x|...} proc Vedi lamda. |
36 | putc( c) Stampa un carattere nell'output predefinito ( $ defout ). |
37 | puts([ str]) Stampa la stringa nell'output predefinito ( $ defout ). Se la stringa non termina con una nuova riga, alla stringa viene aggiunta una nuova riga. |
38 | raise(...) fail(...) Solleva un'eccezione. Presume RuntimeError se non viene specificata alcuna classe di eccezione. La chiamata a raise senza argomenti in una clausola di salvataggio solleva nuovamente l'eccezione. Farlo al di fuori di una clausola di salvataggio solleva un'eccezione RuntimeError senza messaggi .fail è un nome obsoleto per raise. |
39 | rand([ max = 0]) Genera un numero pseudocasuale maggiore o uguale a 0 e minore di max. Se max non è specificato o è impostato su 0, viene restituito un numero casuale come numero a virgola mobile maggiore o uguale a 0 e minore di 1. srand può essere utilizzato per inizializzare il flusso pseudo-casuale. |
40 | readline([ rs = $/]) Equivalente a gets tranne che solleva un'eccezione EOFError alla lettura di EOF. |
41 | readlines([ rs = $/]) Restituisce un array di stringhe che contengono i nomi di file specificati come argomenti della riga di comando o il contenuto dell'input standard. |
42 | require( lib) Carica la libreria (comprese le librerie di estensione) lib quando viene chiamata per la prima volta. require non caricherà la stessa libreria più di una volta. Se nessuna estensione è specificata in lib , require prova ad aggiungere .rb, .so, ecc. Ad essa. |
43 | scan( re) scan( re) {|x|...} Equivalente a $ _. Scan. |
44 | select( reads[, writes = nil[, excepts = nil[, timeout = nil]]]) Verifica la presenza di modifiche nello stato di tre tipi di input, output ed eccezioni di oggetti I / O che vengono passati come array di oggetti I / O. nil viene passato per argomenti che non necessitano di controllo. Viene restituito un array a tre elementi contenente gli array degli oggetti IO per i quali sono state apportate modifiche allo stato. nil viene restituito al timeout. |
45 | set_trace_func( proc) Imposta un gestore per la traccia. proc può essere una stringa o un oggetto proc . set_trace_func viene utilizzato dal debugger e dal profiler. |
46 | sleep([ sec]) Sospende l'esecuzione del programma per secondi secondi. Se sec non è specificato, il programma viene sospeso per sempre. |
47 | split([ sep[, max]]) Equivalente a $ _. Split. |
48 | sprintf( fmt[, arg...]) format( fmt[, arg...]) Restituisce una stringa in cui arg è formattato in base a fmt. Le specifiche di formattazione sono essenzialmente le stesse di sprintf nel linguaggio di programmazione C. Gli specificatori di conversione (% seguito dall'identificatore del campo di conversione) in fmt vengono sostituiti dalla stringa formattata dell'argomento corrispondente. Un elenco delle conversioni archiviate è fornito di seguito nella sezione successiva. |
49 | srand([ seed]) Inizializza un array di numeri casuali. Se il seme non è specificato, l'inizializzazione viene eseguita utilizzando l'ora e altre informazioni di sistema per il seme. |
50 | String( obj) Restituisce obj dopo averlo convertito in una stringa utilizzando obj.to_s. |
51 | syscall( sys[, arg...]) Chiama una funzione di chiamata del sistema operativo specificata da number sys . I numeri e il significato di sys dipendono dal sistema. |
52 | system( cmd[, arg...]) Esegue cmd come una chiamata alla riga di comando. Se vengono specificati più argomenti, il comando viene eseguito direttamente senza espansione della shell. Restituisce vero se lo stato di ritorno è 0 (successo). |
53 | sub( x, y) sub( x) {...} Sostituisce la prima stringa che corrisponde a x in $ _ con y. Se viene specificato un blocco, le stringhe corrispondenti vengono sostituite con il risultato del blocco. Il risultato modificato viene assegnato a $ _. |
54 | sub!( x, y) sub!( x) {...} Esegue la stessa sostituzione del sub, tranne che la stringa viene cambiata in posizione. |
55 | test( test, f1[, f2]) Esegue vari test di file specificati dal carattere di prova . Per migliorare la leggibilità, dovresti usare i metodi della classe File (ad esempio File :: readable?) Piuttosto che questa funzione. Un elenco di argomenti è fornito di seguito nella sezione successiva. |
56 | throw( tag[, value = nil]) Salta alla funzione di cattura in attesa con il simbolo o il tag stringa . valore è il valore restituito da utilizzare da catch . |
57 | trace_var( var, cmd) trace_var( var) {...} Imposta la traccia per una variabile globale. Il nome della variabile viene specificato come simbolo. cmd può essere una stringa o un oggetto Proc. |
58 | trap( sig, cmd) trap( sig) {...} Imposta un gestore del segnale. sig può essere una stringa (come SIGUSR1) o un numero intero. SIG può essere omesso dal nome del segnale. Il gestore del segnale per il segnale EXIT o il segnale numero 0 viene richiamato appena prima della conclusione del processo. |
59 | untrace_var( var[, cmd]) Rimuove la traccia per una variabile globale. Se viene specificato cmd , viene rimosso solo quel comando. |
Funzioni per i numeri
Di seguito è riportato un elenco di funzioni integrate relative al numero. Dovrebbero essere usati come segue:
#!/usr/bin/ruby
num = 12.40
puts num.floor # 12
puts num + 10 # 22.40
puts num.integer? # false as num is a float.
Questo produrrà il seguente risultato:
12
22.4
false
Sr.No. | Metodi e descrizione |
---|---|
1 | n + num n - num n * num n / num Esegue operazioni aritmetiche: addizione, sottrazione, moltiplicazione e divisione. |
2 | n % num Restituisce il modulo di n. |
3 | n ** num Esponenziazione. |
4 | n.abs Restituisce il valore assoluto di n. |
5 | n.ceil Restituisce il numero intero più piccolo maggiore o uguale a n. |
6 | n.coerce( num) Restituisce un array contenente num e n entrambi eventualmente convertiti in un tipo che consente di utilizzarli reciprocamente. Utilizzato nella conversione automatica del tipo negli operatori numerici. |
7 | n.divmod( num) Restituisce un array contenente il quoziente e il modulo dalla divisione n per num. |
8 | n.floor Restituisce il numero intero più grande minore o uguale a n. |
9 | n.integer? Restituisce vero se n è un numero intero. |
10 | n.modulo( num) Restituisce il modulo ottenuto dividendo n per num e arrotondando il quoziente con floor |
11 | n.nonzero? Restituisce n se non è zero, altrimenti nullo. |
12 | n.remainder( num) Restituisce il resto ottenuto dividendo n di nume rimuovendo i decimali dal quoziente. Ilresult e n hanno sempre lo stesso segno. |
13 | n.round Restituisce n arrotondato al numero intero più vicino. |
14 | n.truncate Restituisce n come numero intero senza i decimali. |
15 | n.zero? Restituisce zero se n è 0. |
16 | n & num n | num n ^ num Operazioni bit per bit: AND, OR, XOR e inversione. |
17 | n << num n >> num Spostamento a sinistra bit per bit e spostamento a destra. |
18 | n[num] Restituisce il valore di numesimo bit dal bit meno significativo, che è n [0]. |
19 | n.chr Restituisce una stringa contenente il carattere per il codice carattere n. |
20 | n.next n.succ Restituisce il numero intero successivo che segue n. Equivalente a n + 1. |
21 | n.size Restituisce il numero di byte nella rappresentazione della macchina di n. |
22 | n.step( upto, step) {|n| ...} Itera il blocco da n per upto, incrementando di step ogni volta. |
23 | n.times {|n| ...} Ripete il blocco n volte. |
24 | n.to_f Converte nin un numero in virgola mobile. La conversione in virgola mobile potrebbe perdere le informazioni sulla precisione. |
25 | n.to_int ritorna n dopo la conversione in numero interger. |
Funzioni per Float
Sr.No. | Metodi e descrizione |
---|---|
1 | Float::induced_from(num) Restituisce il risultato della conversione di num in un numero a virgola mobile. |
2 | f.finite? Restituisce vero se f non è infinito e f.nan è falso. |
3 | f.infinite? Restituisce 1 se f è infinito positivo, -1 se infinito negativo o nil se non altro. |
4 | f.nan? Restituisce vero se f non è un numero a virgola mobile IEEE valido. |
Funzioni per la matematica
Sr.No. | Metodi e descrizione |
---|---|
1 | atan2( x, y) Calcola l'arco tangente. |
2 | cos( x) Calcola il coseno di x. |
3 | exp( x) Calcola una funzione esponenziale (e elevata alla potenza di x). |
4 | frexp( x) Restituisce una matrice a due elementi contenente la frazione nominalizzata e l'esponente di x. |
5 | ldexp( x, exp) Restituisce il valore di x per 2 alla potenza di exp. |
6 | log( x) Calcola il logaritmo naturale di x. |
7 | log10( x) Calcola il logaritmo in base 10 di x. |
8 | sin( x) Calcola il seno di x. |
9 | sqrt( x) Restituisce la radice quadrata di x. x deve essere positivo. |
10 | tan( x) Calcola la tangente di x. |
Identificatore del campo di conversione
La funzione sprintf (fmt [, arg ...]) e format (fmt [, arg ...]) restituisce una stringa in cui arg è formattato secondo fmt. Le specifiche di formattazione sono essenzialmente le stesse di sprintf nel linguaggio di programmazione C. Gli specificatori di conversione (% seguito dall'identificatore del campo di conversione) in fmt vengono sostituiti dalla stringa formattata dell'argomento corrispondente.
Sr.No. | Specifier e descrizione |
---|---|
1 | b Numero intero binario |
2 | c Singolo carattere |
3 | d,i Numero intero decimale |
4 | e Notazione esponenziale (ad esempio, 2.44e6) |
5 | E Notazione esponenziale (ad esempio, 2.44E6) |
6 | f Numero in virgola mobile (ad esempio, 2.44) |
7 | g usa% e se l'esponente è minore di -4, altrimenti% f |
8 | G usa% E se l'esponente è minore di -4, altrimenti% f |
9 | o Numero intero ottale |
10 | s Stringa o qualsiasi oggetto convertito utilizzando to_s |
11 | u Numero intero decimale senza segno |
12. | x Numero intero esadecimale (ad es. 39ff) |
13 | X Numero intero esadecimale (ad es. 39FF) |
Di seguito è riportato l'esempio di utilizzo:
#!/usr/bin/ruby
str = sprintf("%s\n", "abc") # => "abc\n" (simplest form)
puts str
str = sprintf("d=%d", 42) # => "d=42" (decimal output)
puts str
str = sprintf("%04x", 255) # => "00ff" (width 4, zero padded)
puts str
str = sprintf("%8s", "hello") # => " hello" (space padded)
puts str
str = sprintf("%.2s", "hello") # => "he" (trimmed by precision)
puts str
Questo produrrà il seguente risultato:
abc
d = 42
00ff
hello
he
Argomenti della funzione di prova
Il test funzionale (test, f1 [, f2]) esegue uno dei seguenti test sui file specificati dal test dei caratteri . Per migliorare la leggibilità, dovresti usare i metodi della classe File (ad esempio, File :: readable?) Piuttosto che questa funzione.
Sr.No. | Argomento e descrizione |
---|---|
1 | ?r F1 è leggibile dall'uid effettivo del chiamante? |
2 | ?w F1 è scrivibile dall'uid effettivo del chiamante? |
3 | ?x F1 è eseguibile dall'uid effettivo del chiamante? |
4 | ?o F1 è di proprietà dell'uid effettivo del chiamante? |
5 | ?R F1 è leggibile dal vero uid del chiamante? |
6 | ?W F1 è scrivibile dal vero uid del chiamante? |
7 | ?X F1 è eseguibile dal vero uid del chiamante? |
8 | ?O F1 è di proprietà del vero uid del chiamante? |
9 | ?e Esiste f1? |
10 | ?z F1 ha lunghezza zero? |
11 | ?s Dimensione del file di f1 (zero se 0) |
12 | ?f F1 è un file normale? |
13 | ?d F1 è una directory? |
14 | ?l F1 è un collegamento simbolico? |
15 | ?p F1 è una named pipe (FIFO)? |
16 | ?S F1 è una presa? |
17 | ?b F1 è un dispositivo a blocchi? |
18 | ?c F1 è un dispositivo a caratteri? |
19 | ?u F1 ha il bit setuid impostato? |
20 | ?g F1 ha il bit setgid impostato? |
21 | ?k F1 ha il bit appiccicoso impostato? |
22 | ?M Ultimo orario di modifica per f1. |
23 | ?A Ultimo orario di accesso per f1. |
24 | ?C Ultimo tempo di cambio inode per f1. |
Sr.No. | Argomento e descrizione |
---|---|
1 | ?= I tempi di modifica di f1 e f2 sono uguali? |
2 | ?> Il tempo di modifica di f1 è più recente di f2? |
3 | ?< Il tempo di modifica di f1 è più vecchio di f2? |
4 | ?- F1 è un collegamento fisso a f2? |
Di seguito è riportato l'esempio di utilizzo. Supponendo che main.rb esista con permessi di lettura, scrittura e non esecuzione -
#!/usr/bin/ruby
puts test(?r, "main.rb" ) # => true
puts test(?w, "main.rb" ) # => true
puts test(?x, "main.rb" ) # => false
Questo produrrà il seguente risultato:
true
false
false
Ruby - Variabili predefinite
Le variabili predefinite di Ruby influenzano il comportamento dell'intero programma, quindi il loro utilizzo nelle librerie non è raccomandato.
È possibile accedere ai valori nella maggior parte delle variabili predefinite con mezzi alternativi.
La tabella seguente elenca tutte le variabili predefinite di Ruby.
Sr.No. | Nome e descrizione della variabile |
---|---|
1 | $! L'ultimo oggetto eccezione sollevato. È possibile accedere all'oggetto eccezione anche utilizzando => nella clausola di salvataggio . |
2 | $@ Il backtrace dello stack per l'ultima eccezione sollevata. Le informazioni di backtrace dello stack possono essere recuperate dal metodo di backtrace dell'eccezione # dell'ultima eccezione. |
3 | $/ Il separatore del record di input (nuova riga per impostazione predefinita). gets, readline, ecc., prendono il separatore di record di input come argomento opzionale. |
4 | $\ Il separatore del record di output (nullo per impostazione predefinita). |
5 | $, Il separatore di output tra gli argomenti da stampare e Array # join (nullo per impostazione predefinita). È possibile specificare il separatore in modo esplicito in Array # join. |
6 | $; Il separatore predefinito per la divisione (zero per impostazione predefinita). È possibile specificare il separatore in modo esplicito per String # split. |
7 | $. Il numero dell'ultima riga letta dal file di input corrente. Equivalente a ARGF.lineno. |
8 | $< Sinonimo di ARGF. |
9 | $> Sinonimo di $ defout. |
10 | $0 Il nome del programma Ruby corrente in esecuzione. |
11 | $$ Il pid del processo del programma Ruby corrente in esecuzione. |
12 | $? Lo stato di uscita dell'ultimo processo è terminato. |
13 | $: Sinonimo di $ LOAD_PATH. |
14 | $DEBUG Vero se viene specificata l'opzione della riga di comando -d o --debug. |
15 | $defout L'output di destinazione per print e printf ( $ stdout per impostazione predefinita). |
16 | $F La variabile che riceve l'output da split quando viene specificato -a. Questa variabile viene impostata se viene specificata l'opzione -a della riga di comando insieme all'opzione -p o -n. |
17 | $FILENAME Il nome del file attualmente letto da ARGF. Equivalente a ARGF.filename. |
18 | $LOAD_PATH Un array che contiene le directory in cui eseguire la ricerca durante il caricamento dei file con i metodi load e require. |
19 | $SAFE Il livello di sicurezza 0 → Nessun controllo viene eseguito sui dati forniti esternamente (contaminati). (predefinito) 1 → Le operazioni potenzialmente pericolose che utilizzano dati contaminati sono vietate. 2 → Sono vietate operazioni potenzialmente pericolose su processi e file. 3 → Tutti gli oggetti appena creati sono considerati contaminati. 4 → La modifica dei dati globali è vietata. |
20 | $stdin Input standard (STDIN per impostazione predefinita). |
21 | $stdout Uscita standard (STDOUT per impostazione predefinita). |
22 | $stderr Errore standard (STDERR per impostazione predefinita). |
23 | $VERBOSE Vero se è specificata l'opzione della riga di comando -v, -w o --verbose. |
24 | $- x Il valore dell'opzione dell'interprete -x (x = 0, a, d, F, i, K, l, p, v). Queste opzioni sono elencate di seguito |
25 | $-0 Il valore dell'opzione dell'interprete -x e l'alias di $ /. |
26 | $-a Il valore dell'opzione -x dell'interprete e vero se l'opzione -a è impostata. Sola lettura. |
27 | $-d Il valore dell'opzione -x dell'interprete e l'alias di $ DEBUG |
28 | $-F Il valore dell'opzione dell'interprete -x e l'alias di $ ;. |
29 | $-i Il valore dell'opzione -x dell'interprete e in modalità di modifica sul posto, mantiene l'estensione, altrimenti è nulla. Può abilitare o disabilitare la modalità di modifica sul posto. |
30 | $-I Il valore dell'opzione dell'interprete -x e l'alias di $ :. |
31 | $-l Il valore dell'opzione -x dell'interprete e vero se l'opzione -l è impostata. Sola lettura. |
32 | $-p Il valore dell'opzione -x dell'interprete e vero se l'opzione -p è impostata. Sola lettura. |
33 | $_ La variabile locale, l'ultima stringa letta da gets o readline nell'ambito corrente. |
34 | $~ La variabile locale MatchData relativa all'ultima corrispondenza. Il metodo di corrispondenza Regex # restituisce le ultime informazioni sulla corrispondenza. |
35 | $ n ($1, $2, $3...) La stringa corrispondente nell'ennesimo gruppo dell'ultima corrispondenza di pattern. Equivalente a m [n], dove m è un oggetto MatchData . |
36 | $& La stringa corrispondente nell'ultima corrispondenza di pattern. Equivalente a m [0], dove m è un oggetto MatchData . |
37 | $` La stringa che precede la corrispondenza nell'ultima corrispondenza del modello. Equivalente a m.pre_match, dove m è un oggetto MatchData . |
38 | $' La stringa che segue la corrispondenza nell'ultima corrispondenza del modello. Equivalente a m.post_match, dove m è un oggetto MatchData. |
39 | $+ La stringa corrispondente all'ultimo gruppo trovato con successo nell'ultima corrispondenza di pattern. |
Ruby - Costanti predefinite
La tabella seguente elenca tutte le costanti predefinite di Ruby -
NOTE- TRUE, FALSE e NIL sono compatibili con le versioni precedenti. È preferibile utilizzare true, false e nil.
Sr.No. | Nome e descrizione della costante |
---|---|
1 | TRUE Sinonimo di vero. |
2 | FALSE Synonym for false. |
3 | NIL Synonym for nil. |
4 | ARGF An object providing access to virtual concatenation of files passed as command-line arguments or standard input if there are no command-line arguments. A synonym for $<. |
5 | ARGV An array containing the command-line arguments passed to the program. A synonym for $*. |
6 | DATA An input stream for reading the lines of code following the __END__ directive. Not defined if __END__ isn't present in code. |
7 | ENV A hash-like object containing the program's environment variables. ENV can be handled as a hash. |
8 | RUBY_PLATFORM A string indicating the platform of the Ruby interpreter. |
9 | RUBY_RELEASE_DATE A string indicating the release date of the Ruby interpreter |
10 | RUBY_VERSION A string indicating the version of the Ruby interpreter. |
11 | STDERR Standard error output stream. Default value of $stderr. |
12 | STDIN Standard input stream. Default value of $stdin. |
13 | STDOUT Standard output stream. Default value of $stdout. |
14 | TOPLEVEL_BINDING A binding object at Ruby's top level. |
Ruby - Associated Tools
Standard Ruby Tools
The standard Ruby distribution contains useful tools along with the interpreter and standard libraries −
These tools help you debug and improve your Ruby programs without spending much effort. This tutorial will give you a very good start with these tools.
RubyGems −
RubyGems is a package utility for Ruby, which installs Ruby software packages and keeps them up-to-date.
Ruby Debugger −
To help deal with bugs, the standard distribution of Ruby includes a debugger. This is very similar to gdb utility, which can be used to debug complex programs.
Interactive Ruby (irb) −
irb (Interactive Ruby) was developed by Keiju Ishitsuka. It allows you to enter commands at the prompt and have the interpreter respond as if you were executing a program. irb is useful to experiment with or to explore Ruby.
Ruby Profiler −
Ruby profiler helps you to improve the performance of a slow program by finding the bottleneck.
Additional Ruby Tools
There are other useful tools that don't come bundled with the Ruby standard distribution. However, you do need to install them yourself.
eRuby: Embeded Ruby −
eRuby stands for embedded Ruby. It's a tool that embeds fragments of Ruby code in other files, such as HTML files similar to ASP, JSP and PHP.
ri: Ruby Interactive Reference −
When you have a question about the behavior of a certain method, you can invoke ri to read the brief explanation of the method.
For more information on Ruby tool and resources, have a look at Ruby Useful Resources.