Comment puis-je obtenir la lettre de lecteur substed en Perl?
-
21-08-2019 - |
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.
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: