Właśnie potrzebowałem tego samego, o co OP pyta, a po wyszukaniu w Google i przeczytaniu odpowiedzi, żadne z nich nie podało tego, co myślę, że OP i ja szukam.
Problem polega na tym, że można zmapować udział sieciowy, Drive Y
podczas gdy ktoś inny w organizacji może mieć przypisany taki sam udział sieciowy jak Drive X
; dlatego przesłanie takiego linku Y:\mydirectory
może nie działać dla nikogo oprócz mnie.
Jak wyjaśnia OP, Explorer pokazuje rzeczywistą ścieżkę na pasku Eksploratora, ale nie można jej skopiować (pisanie jest uciążliwe i podatne na błędy, więc nie jest to opcja), nawet jeśli wybierzesz copy as path
z menu kontekstowego:
Tak więc rozwiązaniem, które wymyśliłem (przez skopiowanie kodu innej osoby) był mały program w języku C #, który można wywołać z menu kontekstowego w Eksploratorze i który pozwoli ci przetłumaczyć literę zamapowanego dysku na rzeczywistą UNC path
.
Oto kod:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace Utils
{
//This is the only piece of code I wrote
class Program
{
[STAThread]
static void Main(string[] args)
{
//Takes the parameter from the command line. Since this will
//be called from the context menu, the context menu will pass it
//via %1 (see registry instructions below)
if (args.Length == 1)
{
Clipboard.SetText(Pathing.GetUNCPath(args[0]));
}
else
{
//This is so you can assign a shortcut to the program and be able to
//Call it pressing the shortcut you assign. The program will take
//whatever string is in the Clipboard and convert it to the UNC path
//For example, you can do "Copy as Path" and then press the shortcut you
//assigned to this program. You can then press ctrl-v and it will
//contain the UNC path
Clipboard.SetText(Pathing.GetUNCPath(Clipboard.GetText()));
}
}
}
}
A oto Pathing
definicja klasy (postaram się znaleźć rzeczywiste źródło, ponieważ nie pamiętam, gdzie je znalazłem):
public static class Pathing
{
[DllImport("mpr.dll", CharSet = CharSet.Unicode, SetLastError = true)]
public static extern int WNetGetConnection(
[MarshalAs(UnmanagedType.LPTStr)] string localName,
[MarshalAs(UnmanagedType.LPTStr)] StringBuilder remoteName,
ref int length);
/// <summary>
/// Given a path, returns the UNC path or the original. (No exceptions
/// are raised by this function directly). For example, "P:\2008-02-29"
/// might return: "\\networkserver\Shares\Photos\2008-02-09"
/// </summary>
/// <param name="originalPath">The path to convert to a UNC Path</param>
/// <returns>A UNC path. If a network drive letter is specified, the
/// drive letter is converted to a UNC or network path. If the
/// originalPath cannot be converted, it is returned unchanged.</returns>
public static string GetUNCPath(string originalPath)
{
StringBuilder sb = new StringBuilder(512);
int size = sb.Capacity;
// look for the {LETTER}: combination ...
if (originalPath.Length > 2 && originalPath[1] == ':')
{
// don't use char.IsLetter here - as that can be misleading
// the only valid drive letters are a-z && A-Z.
char c = originalPath[0];
if ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'))
{
int error = WNetGetConnection(originalPath.Substring(0, 2),
sb, ref size);
if (error == 0)
{
DirectoryInfo dir = new DirectoryInfo(originalPath);
string path = Path.GetFullPath(originalPath)
.Substring(Path.GetPathRoot(originalPath).Length);
return Path.Combine(sb.ToString().TrimEnd(), path);
}
}
}
return originalPath;
}
}
Budujesz program i umieszczasz plik wykonywalny gdzieś na komputerze, powiedzmy na przykład c:\Utils
Teraz dodajesz opcję menu kontekstowego w Eksploratorze, ponieważ:
Regedit, a następnie:
HKEY_CLASSES_ROOT\*\Directory\Shell
Right-click Shell --> New Key --> Name: "To UNC Path"
Right-click To UNC Path --> New Key --> Name: command
Right-click Default entry and select `Modify`
Value Data: c:\Utils\Utils.exe "%1"
Gotowe. Teraz zobaczysz tę opcję po kliknięciu prawym przyciskiem myszy katalog z zamapowanego dysku:
Uwaga
Mogę dostarczyć plik wykonywalny, abyś nie musiał sam kompilować. Po prostu napisz mi tutaj notatkę.