Question

Je dois me substed lettre de lecteur en Perl. Quelqu'un pourrait-il bien vouloir me aider? $ ENV {} SYSTEMDRIVE ne fonctionne pas; il me donne la lettre de lecteur logique réelle, pas celle substed.

Était-ce utile?

La solution 2

Merci à tous, enfin je l'ai résolu par beaucoup plus facile - en utilisant la commande getcwd pour obtenir le répertoire de travail en cours, puis j'ai utilisé deux premières lettres de sa sortie - si simple :-)

use Cwd;

my $driveletter = substr(getcwd, 0, 2); 

Autres conseils

Vous cherchez Win32 :: FileOp ?

Si vous voulez faire vous-même, vous pourriez capturer la sortie de la commande et le traiter Subst, car il génère tous les lecteurs substitués actuels.

SUBST [drive1: [drive2:]path]
SUBST drive1: /D
    drive1:        Specifies a virtual drive to which you want to assign a path.
    [drive2:]path  Specifies a physical drive and path you want to assign to
                   a virtual drive.
    /D             Deletes a substituted (virtual) drive.
Type SUBST with no parameters to display a list of current virtual drives.

C:\Documents and Settings\Administrator\My Documents>subst r: c:\bin

C:\Documents and Settings\Administrator\My Documents>subst
    R:\: => C:\bin

Pour ce faire, vous avez besoin d'une fonction pour renvoyer la sortie subst'ed, comme suit:

sub get_drive {
    my $drv = shift;
    my $ln;
    $drv = substr($drv,0,1);
    open (IN, "subst |");
    while ($ln = <IN>) {
            chomp ($ln);
            if ((substr($ln,0,1) eq $drv) && (substr($ln,1,6) eq ":\\: =>")) {
                    close (IN);
                    return substr($ln,8);
            }
    }
    close (IN);
    return $drv . ":\\";
}

print get_drive ("R:") . "\n";
print get_drive ("S:") . "\n";

Sorties:

C:\bin
S:\

sur mon système qui a seulement un lecteur subst'ed.

(réponse très tard, je sais), mais seulement aujourd'hui je besoin de quelque chose comme ça et Win32 :: FileOp ne compilerait pas sur mon système. Alors j'invoquais et Subst substituais lecteurs virtuels avec « réel »; extrait suit:

use strict;
use Data::Dumper;
use feature 'say';

my $DB=1;

$Data::Dumper::Indent = 1;
$Data::Dumper::Terse  = 1;
my %Virt;

exit main();

sub main
{
    my $rtn;
    my (@args) = @_;
    open CMD,"subst|" or die "can't run subst command";
    while (<CMD>) {
        chomp;
        my ($drv, $path) = split(/:\\: => /);
        $Virt{$drv} = $path;
    }

    my %rset; # result set
    while (my ($d,$p) = each %Virt) {
        $rset{$d} = expand($p);
    }
    #D say Dumper rset => \%rset;
    return $rtn;
}

# recursive call if expanded path has another 'virtual' drive
sub expand
{
    my ($loc) = @_;
    my $rtn = undef;
    my ($drv, $path) =  split(/:\\/, $loc);
    if ($a = $Virt{$drv}) {
        #D say "$a $path";
        $rtn = "$a\\$path";
        $rtn = expand($rtn);
    } else {
        #D say "$drv $path";
        $rtn = "$drv:\\$path";
    }
    return $rtn;
}

Notes: J'utilise pour #D instructions de débogage quickNdirty

I testé ce à trois niveaux à savoir w: subst à x :, x: subst à y: et y: subst c:

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top