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
:: Operatore a risoluzione costante
[] [] = Riferimento elemento, set di elementi
** Esponenziazione (aumento alla potenza)
! ~ + - No, complemento, più e meno unario (i nomi dei metodi per gli ultimi due sono + @ e - @)
* /% Moltiplica, dividi e modulo
+ - Addizione e sottrazione
>> << Spostamento bit per bit destro e sinistro
& Bitwise "AND"
^ | "OR" esclusivo bit per bit e "OR" regolare
<= <>> = Operatori di confronto
<=> == ===! = = ~! ~ 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 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 . 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 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 . 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 . 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:

&lt;h1&gt;Zara Ali/A Sweet & Sour Girl&lt;/h1&gt;'

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.