Perl - Dosya G / Ç

Dosyaları işlemenin temelleri basittir: bir filehandle harici bir varlık ile (genellikle bir dosya) ve ardından dosya tanıtıcısı ile ilişkili veri akışında depolanan verileri okumak ve güncellemek için Perl içinde çeşitli işleçler ve işlevler kullanın.

Dosya tanıtıcısı, fiziksel bir dosyayı bir adla ilişkilendiren adlandırılmış bir dahili Perl yapısıdır. Tüm dosya tanıtıcıları okuma / yazma erişimine sahiptir, böylece bir dosya tanıtıcısı ile ilişkili herhangi bir dosya veya cihazdan okuyabilir ve bunları güncelleyebilirsiniz. Bununla birlikte, bir dosya tanıtıcısı ilişkilendirdiğinizde, dosya tanıtıcısının açılacağı modu belirtebilirsiniz.

Üç temel dosya tanıtıcısı şunlardır: STDIN, STDOUT, ve STDERR, sırasıyla standart girişi, standart çıkışı ve standart hata cihazlarını temsil eder.

Dosyaları Açma ve Kapatma

Perl'de herhangi bir yeni veya mevcut dosyayı açmak için kullanılabilen, birden çok formda aşağıdaki iki işlev vardır.

open FILEHANDLE, EXPR
open FILEHANDLE

sysopen FILEHANDLE, FILENAME, MODE, PERMS
sysopen FILEHANDLE, FILENAME, MODE

Burada FILEHANDLE, tarafından döndürülen dosya tanıtıcısıdır. open işlev ve EXPR, dosya adına ve dosyayı açma moduna sahip ifadedir.

Açık Fonksiyon

Açılacak sözdizimi aşağıdadır file.txtsalt okunur modda. Burada <işaretinden küçük olması dosyanın salt okunur modda açılması gerektiğini belirtir.

open(DATA, "<file.txt");

Burada DATA, dosyayı okumak için kullanılacak olan dosya tanıtıcısıdır. İşte bir dosyayı açacak ve içeriğini ekran üzerinde yazdıracak örnek.

#!/usr/bin/perl

open(DATA, "<file.txt") or die "Couldn't open file file.txt, $!";

while(<DATA>) {
   print "$_";
}

Dosya.txt dosyasını yazma modunda açmak için sözdizimi aşağıdadır. Burada> işaretinden küçük olması dosyanın yazma modunda açılması gerektiğini gösterir.

open(DATA, ">file.txt") or die "Couldn't open file file.txt, $!";

Bu örnek aslında dosyayı yazmak için açmadan önce keser (boşaltır), ki bu istenen etki olmayabilir. Bir dosyayı okumak ve yazmak için açmak istiyorsanız,> veya <karakterlerinin önüne bir artı işareti koyabilirsiniz.

Örneğin, bir dosyayı kesmeden güncellemek için açmak -

open(DATA, "+<file.txt"); or die "Couldn't open file file.txt, $!";

Önce dosyayı kesmek için -

open DATA, "+>file.txt" or die "Couldn't open file file.txt, $!";

Ekleme modunda bir dosya açabilirsiniz. Bu modda, yazma noktası dosyanın sonuna ayarlanacaktır.

open(DATA,">>file.txt") || die "Couldn't open file file.txt, $!";

Çift >> dosyayı eklemek için açar ve dosya işaretçisini sona yerleştirir, böylece hemen bilgi eklemeye başlayabilirsiniz. Ancak, önüne artı işareti koymadıkça okuyamazsınız -

open(DATA,"+>>file.txt") || die "Couldn't open file file.txt, $!";

Aşağıda, farklı modların olası değerlerini veren tablo yer almaktadır.

Sr.No. Varlıklar ve Tanım
1

< or r

Salt Okunur Erişim

2

> or w

Oluşturur, Yazır ve Keser

3

>> or a

Yazıyor, Ekliyor ve Oluşturuyor

4

+< or r+

Okur ve Yazarlar

5

+> or w+

Okur, Yazır, Oluşturur ve Keser

6

+>> or a+

Okur, Yazır, Ekler ve Oluşturur

Sysopen İşlevi

sysopen işlevi, sistemi kullanması dışında ana açık işlevine benzer open() işlevi, kendisine sağlanan parametreleri sistem işlevi için parametreler olarak kullanarak -

Örneğin, güncelleme için bir dosya açmak için +<filename açık biçimden -

sysopen(DATA, "file.txt", O_RDWR);

Veya güncellemeden önce dosyayı kesmek için -

sysopen(DATA, "file.txt", O_RDWR|O_TRUNC );

Yeni bir dosya oluşturmak için O_CREAT'i ve dosyayı salt yazma modunda açmak için O_WRONLY'yi ve dosyayı salt okunur modda açmak için O_RDONLY'yi kullanabilirsiniz.

PERMSargüman, oluşturulması gerekiyorsa, belirtilen dosya için dosya izinlerini belirtir. Varsayılan olarak alır0x666.

Aşağıda MODE'nin olası değerlerini veren tablo yer almaktadır.

Sr.No. Varlıklar ve Tanım
1

O_RDWR

Oku ve yaz

2

O_RDONLY

Sadece oku

3

O_WRONLY

Yalnızca Yazma

4

O_CREAT

Dosyayı oluşturun

5

O_APPEND

Dosyayı ekleyin

6

O_TRUNC

Dosyayı kes

7

O_EXCL

Dosya zaten mevcutsa durur

8

O_NONBLOCK

Engellemeyen kullanılabilirlik

Kapat Fonksiyonu

Bir dosya tanıtıcısını kapatmak ve dolayısıyla dosya tanıtıcısının ilgili dosyayla ilişkisini kesmek için, closeişlevi. Bu, dosya tanıtıcısının arabelleklerini temizler ve sistemin dosya tanımlayıcısını kapatır.

close FILEHANDLE
close

FILEHANDLE belirtilmezse, o anda seçili olan dosya tanıtıcısını kapatır. Yalnızca arabellekleri başarıyla temizleyip dosyayı kapatabilirse true döndürür.

close(DATA) || die "Couldn't close file properly";

Dosyaları Okuma ve Yazma

Açık bir dosya tanıtıcınız olduğunda, bilgileri okuyup yazabilmeniz gerekir. Dosyaya veri okumanın ve yazmanın birkaç farklı yolu vardır.

<FILEHANDL> Operatörü

Açık bir dosya tanıtıcısından bilgileri okumanın ana yöntemi <FILEHANDLE> operatördür. Skaler bir bağlamda, dosya tanıtıcısından tek bir satır döndürür. Örneğin -

#!/usr/bin/perl

print "What is your name?\n";
$name = <STDIN>;
print "Hello $name\n";

<FILEHANDLE> operatörünü bir liste bağlamında kullandığınızda, belirtilen dosya tanıtıcısından satırların bir listesini döndürür. Örneğin, bir dosyadaki tüm satırları bir diziye aktarmak için -

#!/usr/bin/perl

open(DATA,"<import.txt") or die "Can't open data";
@lines = <DATA>;
close(DATA);

getc İşlevi

Getc işlevi belirtilen FILEHANDLE'dan tek bir karakter veya hiçbiri belirtilmemişse STDIN döndürür -

getc FILEHANDLE
getc

Bir hata varsa veya dosya tanıtıcısı dosyanın sonundaysa bunun yerine undef döndürülür.

Fonksiyonu oku

Okuma işlevi, arabelleğe alınmış dosya tanıtıcısından bir bilgi bloğunu okur: Bu işlev, dosyadan ikili verileri okumak için kullanılır.

read FILEHANDLE, SCALAR, LENGTH, OFFSET
read FILEHANDLE, SCALAR, LENGTH

Okunan verinin uzunluğu LENGTH ile tanımlanır ve veri OFFSET belirtilmemişse SCALAR'ın başlangıcına yerleştirilir. Aksi takdirde veriler SCALAR'da OFFSET baytlarından sonra yerleştirilir. İşlev, başarı durumunda okunan bayt sayısını, dosyanın sonunda sıfır veya bir hata varsa undef döndürür.

yazdırma İşlevi

Dosya tanıtıcılarından bilgi okumak için kullanılan tüm farklı yöntemler için, bilgileri geri yazmanın ana işlevi yazdırma işlevidir.

print FILEHANDLE LIST
print LIST
print

Yazdırma işlevi, LIST'in değerlendirilen değerini FILEHANDLE'a veya geçerli çıktı dosya tanıtıcısına (varsayılan olarak STDOUT) yazdırır. Örneğin -

print "Hello World!\n";

Dosyalar kopyalanıyor

İşte dosya1.txt dosyasını açan ve satır satır okuyan ve başka bir dosya2.txt dosyası oluşturan örnek.

#!/usr/bin/perl

# Open file to read
open(DATA1, "<file1.txt");

# Open new file to write
open(DATA2, ">file2.txt");

# Copy data from one file to another.
while(<DATA1>) {
   print DATA2 $_;
}
close( DATA1 );
close( DATA2 );

Bir dosyayı yeniden adlandırma

İşte file1.txt dosyasını file2.txt olarak nasıl yeniden adlandırabileceğimizi gösteren bir örnek. Varsayalım ki dosya / usr / test dizininde bulunur.

#!/usr/bin/perl

rename ("/usr/test/file1.txt", "/usr/test/file2.txt" );

Bu işlev renames iki argüman alır ve sadece mevcut dosyayı yeniden adlandırır.

Mevcut bir Dosyayı Silme

Burada bir file1.txt dosyasının nasıl silineceğini gösteren bir örnek. unlink işlevi.

#!/usr/bin/perl

unlink ("/usr/test/file1.txt");

Bir Dosyanın İçinde Konumlandırma

İçin kullanabilirsiniz tell bir dosyanın mevcut konumunu bilmek için işlev ve seek dosya içinde belirli bir konumu işaret etme işlevi.

tell Function

İlk gereksinim, tell işlevini kullanarak yaptığınız bir dosya içindeki konumunuzu bulmaktır -

tell FILEHANDLE
tell

Bu, belirtilmişse FILEHANDLE içindeki dosya işaretçisinin konumunu bayt cinsinden veya hiçbiri belirtilmemişse geçerli varsayılan seçili dosya tanıtıcısını döndürür.

arama İşlevi

Arama işlevi, dosya işaretçisini bir dosya içinde belirtilen bayta göre konumlandırır -

seek FILEHANDLE, POSITION, WHENCE

İşlev, fseek sistem işlevini kullanır ve üç farklı noktaya göre aynı konumlandırma yeteneğine sahip olursunuz: başlangıç, bitiş ve geçerli konum. Bunu, WHENCE için bir değer belirleyerek yaparsınız.

Sıfır, konumlandırmayı dosyanın başlangıcına göre ayarlar. Örneğin, satır, dosya işaretçisini dosyadaki 256. bayta ayarlar.

seek DATA, 256, 0;

Dosya bilgisi

Toplu olarak -X testleri olarak bilinen bir dizi test operatörü kullanarak Perl içinde belirli özellikleri çok hızlı bir şekilde test edebilirsiniz. Örneğin, bir dosyadaki çeşitli izinlerin hızlı bir testini gerçekleştirmek için şuna benzer bir komut dosyası kullanabilirsiniz -

#/usr/bin/perl

my $file = "/usr/test/file1.txt";
my (@description, $size);
if (-e $file) {
   push @description, 'binary' if (-B _);
   push @description, 'a socket' if (-S _);
   push @description, 'a text file' if (-T _);
   push @description, 'a block special file' if (-b _);
   push @description, 'a character special file' if (-c _);
   push @description, 'a directory' if (-d _);
   push @description, 'executable' if (-x _);
   push @description, (($size = -s _)) ? "$size bytes" : 'empty';
   print "$file is ", join(', ',@description),"\n";
}

İşte bir dosya veya dizini kontrol edebileceğiniz özelliklerin listesi -

Sr.No. Operatör ve Tanım
1

-A

Komut dosyası başlangıç ​​zamanı eksi dosya son erişim süresi, gün cinsinden.

2

-B

İkili dosya mı?

3

-C

Komut dosyası başlangıç ​​zamanı eksi dosya son inode değişiklik zamanı, gün cinsinden.

3

-M

Komut dosyası başlangıç ​​zamanı eksi dosya değiştirme süresi, gün cinsinden.

4

-O

Dosyanın sahibi gerçek kullanıcı kimliğine mi ait?

5

-R

Dosya gerçek kullanıcı kimliği veya gerçek grup tarafından okunabilir mi?

6

-S

Dosya bir soket mi?

7

-T

Bu bir metin dosyası mı?

8

-W

Dosya gerçek kullanıcı kimliği veya gerçek grup tarafından yazılabilir mi?

9

-X

Dosya gerçek kullanıcı kimliği veya gerçek grup tarafından yürütülebilir mi?

10

-b

Blok özel bir dosya mı?

11

-c

Özel bir karakter dosyası mı?

12

-d

Dosya bir dizin mi?

13

-e

Dosya var mı?

14

-f

Düz bir dosya mı?

15

-g

Dosyada setgid bit seti var mı?

16

-k

Dosyada yapışkan bit ayarlanmış mı?

17

-l

Dosya sembolik bir bağlantı mı?

18

-o

Dosyanın sahibi etkili kullanıcı kimliğine mi ait?

19

-p

Dosya adlandırılmış bir kanal mı?

20

-r

Dosya, etkili kullanıcı veya grup kimliği tarafından okunabilir mi?

21

-s

Sıfır boyut = boş dosya olarak dosyanın boyutunu döndürür.

22

-t

Dosya tanıtıcısı bir TTY (terminal) tarafından mı açıldı?

23

-u

Dosyada setuid bit seti var mı?

24

-w

Dosya etkin kullanıcı veya grup kimliği ile yazılabilir mi?

25

-x

Dosya, etkin kullanıcı veya grup kimliği tarafından yürütülebilir mi?

26

-z

Dosya boyutu sıfır mı?