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 .