Ruby - E / S de fichier
Ruby fournit un ensemble complet de méthodes liées aux E / S implémentées dans le module Kernel. Toutes les méthodes d'E / S sont dérivées de la classe IO.
La classe IO fournit toutes les méthodes de base, telles que read, write, gets, put, readline, getc et printf .
Ce chapitre couvrira toutes les fonctions d'E / S de base disponibles dans Ruby. Pour plus de fonctions, reportez-vous à Ruby Class IO .
La déclaration put
Dans les chapitres précédents, vous avez affecté des valeurs aux variables, puis imprimé la sortie à l'aide de l' instruction put .
La met déclaration indique au programme pour afficher la valeur stockée dans la variable. Cela ajoutera une nouvelle ligne à la fin de chaque ligne qu'il écrit.
Exemple
#!/usr/bin/ruby
val1 = "This is variable one"
val2 = "This is variable two"
puts val1
puts val2
Cela produira le résultat suivant -
This is variable one
This is variable two
La déclaration gets
L' instruction gets peut être utilisée pour prendre n'importe quelle entrée de l'utilisateur à partir de l'écran standard appelé STDIN.
Exemple
Le code suivant vous montre comment utiliser l'instruction gets. Ce code invitera l'utilisateur à entrer une valeur, qui sera stockée dans une variable val et finalement imprimée sur STDOUT.
#!/usr/bin/ruby
puts "Enter a value :"
val = gets
puts val
Cela produira le résultat suivant -
Enter a value :
This is entered value
This is entered value
La déclaration putc
Contrairement à la puts déclaration, qui sort l'intégralité de la chaîne sur l'écran, la putc déclaration peut être utilisée pour afficher un caractère à la fois.
Exemple
La sortie du code suivant est juste le caractère H -
#!/usr/bin/ruby
str = "Hello Ruby!"
putc str
Cela produira le résultat suivant -
H
La déclaration imprimée
L' instruction print est similaire à l' instruction put . La seule différence est que l' instruction put passe à la ligne suivante après l'impression du contenu, alors qu'avec l' instruction print , le curseur est positionné sur la même ligne.
Exemple
#!/usr/bin/ruby
print "Hello World"
print "Good Morning"
Cela produira le résultat suivant -
Hello WorldGood Morning
Ouverture et fermeture de fichiers
Jusqu'à présent, vous lisiez et écriviez sur l'entrée et la sortie standard. Maintenant, nous allons voir comment jouer avec des fichiers de données réels.
La méthode File.new
Vous pouvez créer un objet File à l' aide de la méthode File.new pour lire, écrire ou les deux, selon la chaîne de mode. Enfin, vous pouvez utiliser la méthode File.close pour fermer ce fichier.
Syntaxe
aFile = File.new("filename", "mode")
# ... process the file
aFile.close
La méthode File.open
Vous pouvez utiliser la méthode File.open pour créer un nouvel objet fichier et affecter cet objet fichier à un fichier. Cependant, il existe une différence entre les méthodes File.open et File.new . La différence est que la méthode File.open peut être associée à un bloc, alors que vous ne pouvez pas faire de même avec la méthode File.new .
File.open("filename", "mode") do |aFile|
# ... process the file
end
N ° Sr. | Modes et description |
---|---|
1 | r Mode lecture seule. Le pointeur de fichier est placé au début du fichier. C'est le mode par défaut. |
2 | r+ Mode lecture-écriture. Le pointeur de fichier sera au début du fichier. |
3 | w Mode écriture seule. Remplace le fichier si le fichier existe. Si le fichier n'existe pas, crée un nouveau fichier à écrire. |
4 | w+ Mode lecture-écriture. Remplace le fichier existant si le fichier existe. Si le fichier n'existe pas, crée un nouveau fichier pour la lecture et l'écriture. |
5 | a Mode écriture seule. Le pointeur de fichier est à la fin du fichier si le fichier existe. Autrement dit, le fichier est en mode ajout. Si le fichier n'existe pas, il crée un nouveau fichier à écrire. |
6 | a+ Mode lecture et écriture. Le pointeur de fichier est à la fin du fichier si le fichier existe. Le fichier s'ouvre en mode ajout. Si le fichier n'existe pas, il crée un nouveau fichier pour la lecture et l'écriture. |
Lecture et écriture de fichiers
Les mêmes méthodes que nous utilisons pour les E / S «simples» sont disponibles pour tous les objets fichier. Ainsi, gets lit une ligne à partir de l'entrée standard, et aFile.gets lit une ligne à partir de l'objet fichier aFile.
Cependant, les objets d'E / S fournissent un ensemble supplémentaire de méthodes d'accès pour nous faciliter la vie.
La méthode sysread
Vous pouvez utiliser la méthode sysread pour lire le contenu d'un fichier. Vous pouvez ouvrir le fichier dans l'un des modes lorsque vous utilisez la méthode sysread. Par exemple -
Voici le fichier texte d'entrée -
This is a simple text file for testing purpose.
Essayons maintenant de lire ce fichier -
#!/usr/bin/ruby
aFile = File.new("input.txt", "r")
if aFile
content = aFile.sysread(20)
puts content
else
puts "Unable to open file!"
end
Cette instruction affichera les 20 premiers caractères du fichier. Le pointeur de fichier sera maintenant placé au 21e caractère du fichier.
La méthode syswrite
Vous pouvez utiliser la méthode syswrite pour écrire le contenu dans un fichier. Vous devez ouvrir le fichier en mode écriture lorsque vous utilisez la méthode syswrite. Par exemple -
#!/usr/bin/ruby
aFile = File.new("input.txt", "r+")
if aFile
aFile.syswrite("ABCDEF")
else
puts "Unable to open file!"
end
Cette instruction écrira "ABCDEF" dans le fichier.
La méthode each_byte
Cette méthode appartient à la classe File . La méthode each_byte est toujours associée à un bloc. Considérez l'exemple de code suivant -
#!/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
Les caractères sont passés un par un à la variable ch puis affichés à l'écran comme suit -
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...
.
.
La méthode IO.readlines
La classe File est une sous-classe de la classe IO. La classe IO a également des méthodes qui peuvent être utilisées pour manipuler des fichiers.
L'une des méthodes de classe IO est IO.readlines . Cette méthode retourne le contenu du fichier ligne par ligne. Le code suivant affiche l'utilisation de la méthode IO.readlines -
#!/usr/bin/ruby
arr = IO.readlines("input.txt")
puts arr[0]
puts arr[1]
Dans ce code, la variable arr est un tableau. Chaque ligne du fichier input.txt sera un élément du tableau arr. Par conséquent, arr [0] contiendra la première ligne, tandis que arr [1] contiendra la deuxième ligne du fichier.
La méthode IO.foreach
Cette méthode renvoie également la sortie ligne par ligne. La différence entre la méthode foreach et la méthode readlines est que la méthode foreach est associée à un bloc. Cependant, contrairement à la méthode readlines , la méthode foreach ne renvoie pas de tableau. Par exemple -
#!/usr/bin/ruby
IO.foreach("input.txt"){|block| puts block}
Ce code transmettra le contenu du fichier test ligne par ligne au bloc variable, puis la sortie sera affichée à l'écran.
Renommer et supprimer des fichiers
Vous pouvez renommer et supprimer des fichiers par programme avec Ruby avec les méthodes renommer et supprimer .
Voici l'exemple pour renommer un fichier existant test1.txt -
#!/usr/bin/ruby
# Rename a file from test1.txt to test2.txt
File.rename( "test1.txt", "test2.txt" )
Voici l'exemple pour supprimer un fichier existant test2.txt -
#!/usr/bin/ruby
# Delete file test2.txt
File.delete("test2.txt")
Modes de fichier et propriété
Utilisez la méthode chmod avec un masque pour changer le mode ou les permissions / liste d'accès d'un fichier -
Voici l'exemple pour changer le mode d'un fichier test.txt existant en une valeur de masque -
#!/usr/bin/ruby
file = File.new( "test.txt", "w" )
file.chmod( 0755 )
N ° Sr. | Masque et description |
---|---|
1 | 0700 masque rwx pour le propriétaire |
2 | 0400 r pour le propriétaire |
3 | 0200 w pour le propriétaire |
4 | 0100 x pour le propriétaire |
5 | 0070 masque rwx pour groupe |
6 | 0040 r pour groupe |
sept | 0020 w pour groupe |
8 | 0010 x pour groupe |
9 | 0007 masque rwx pour autre |
dix | 0004 r pour autre |
11 | 0002 w pour autre |
12 | 0001 x pour autre |
13 | 4000 Définir l'ID utilisateur lors de l'exécution |
14 | 2000 Définir l'ID de groupe lors de l'exécution |
15 | 1000 Enregistrez le texte permuté, même après utilisation |
Demandes de dossier
La commande suivante teste si un fichier existe avant de l'ouvrir -
#!/usr/bin/ruby
File.open("file.rb") if File::exists?( "file.rb" )
La commande suivante demande si le fichier est vraiment un fichier -
#!/usr/bin/ruby
# This returns either true or false
File.file?( "text.txt" )
La commande suivante détermine si le nom de fichier donné est un répertoire -
#!/usr/bin/ruby
# a directory
File::directory?( "/usr/local/bin" ) # => true
# a file
File::directory?( "file.rb" ) # => false
La commande suivante détermine si le fichier est lisible, inscriptible ou exécutable -
#!/usr/bin/ruby
File.readable?( "test.txt" ) # => true
File.writable?( "test.txt" ) # => true
File.executable?( "test.txt" ) # => false
La commande suivante détermine si le fichier a une taille nulle ou non -
#!/usr/bin/ruby
File.zero?( "test.txt" ) # => true
La commande suivante renvoie la taille du fichier -
#!/usr/bin/ruby
File.size?( "text.txt" ) # => 1002
La commande suivante peut être utilisée pour trouver un type de fichier -
#!/usr/bin/ruby
File::ftype( "test.txt" ) # => file
La méthode ftype identifie le type du fichier en renvoyant l'un des éléments suivants: fichier, répertoire, characterSpecial, blockSpecial, fifo, link, socket ou unknown.
La commande suivante peut être utilisée pour trouver quand un fichier a été créé, modifié ou accédé pour la dernière fois -
#!/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
Répertoires en Ruby
Tous les fichiers sont contenus dans divers répertoires et Ruby n'a aucun problème à les gérer. Alors que la classe File gère les fichiers, les répertoires sont gérés avec la classe Dir .
Naviguer dans les répertoires
Pour changer de répertoire dans un programme Ruby, utilisez Dir.chdir comme suit. Cet exemple change le répertoire actuel en / usr / bin .
Dir.chdir("/usr/bin")
Vous pouvez trouver quel est le répertoire actuel avec Dir.pwd -
puts Dir.pwd # This will return something like /usr/bin
Vous pouvez obtenir une liste des fichiers et des répertoires dans un répertoire spécifique en utilisant Dir.entries -
puts Dir.entries("/usr/bin").join(' ')
Dir.entries renvoie un tableau avec toutes les entrées dans le répertoire spécifié. Dir.foreach offre la même fonctionnalité -
Dir.foreach("/usr/bin") do |entry|
puts entry
end
Un moyen encore plus concis d'obtenir des listes de répertoires consiste à utiliser la méthode de tableau de classe de Dir -
Dir["/usr/bin/*"]
Créer un annuaire
Le Dir.mkdir peut être utilisé pour créer des répertoires -
Dir.mkdir("mynewdir")
Vous pouvez également définir des autorisations sur un nouveau répertoire (pas un qui existe déjà) avec mkdir -
NOTE - Le masque 755 définit les droits du propriétaire, du groupe, du monde [n'importe qui] sur rwxr-xr-x où r = lecture, w = écriture et x = exécution.
Dir.mkdir( "mynewdir", 755 )
Supprimer un répertoire
Le Dir.delete peut être utilisé pour supprimer un répertoire. Les Dir.unlink et Dir.rmdir effectue exactement la même fonction et sont fournis pour la commodité.
Dir.delete("testdir")
Création de fichiers et de répertoires temporaires
Les fichiers temporaires sont ceux qui peuvent être créés brièvement pendant l'exécution d'un programme, mais ne sont pas une réserve permanente d'informations.
Dir.tmpdir fournit le chemin d'accès au répertoire temporaire sur le système actuel, bien que la méthode ne soit pas disponible par défaut. Pour rendre Dir.tmpdir disponible, il est nécessaire d'utiliser require 'tmpdir'.
Vous pouvez utiliser Dir.tmpdir avec File.join pour créer un fichier temporaire indépendant de la plate-forme -
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)
Ce code crée un fichier temporaire, y écrit des données et le supprime. La bibliothèque standard de Ruby comprend également une bibliothèque appelée Tempfile qui peut créer des fichiers temporaires pour vous -
require 'tempfile'
f = Tempfile.new('tingtong')
f.puts "Hello"
puts f.path
f.close
Fonctions intégrées
Voici les fonctions intégrées de ruby pour traiter les fichiers et les répertoires -
Classe et méthodes de fichier .
Classe et méthodes de Dir .