2011-12-06 13 views
6

Vorrei troncare un percorso lungo a una lunghezza specifica. Tuttavia, voglio avere l'ellissi nel mezzo.Percorso lungo con puntini di sospensione nel mezzo

ad esempio: \\my\long\path\is\really\long\and\it\needs\to\be\truncated dovrebbe diventare (troncato a 35 caratteri): \\my\long\path\is...to\be\truncated

C'è una funzione standard o metodo di estensione disponibili?

+0

Questo è anche ben risposto in http://stackoverflow.com/questions/8360360/c-sharp-function-to-shrink-file-path-to-be-more-human-readble –

risposta

4

Non esiste una funzione standard o un metodo di estensione, quindi è necessario eseguire il rollover.

Verificare la lunghezza e utilizzare qualcosa come;

var truncated = ts.Substring(0, 16) + "..." + ts.Substring((ts.Length - 16), 16); 
+0

Accettato. Ho un codice simile per farlo, volevo solo renderlo più pulito. – Vivek

1

Questo funziona

// Specify max width of resulting file name 
    const int MAX_WIDTH = 50; 

    // Specify long file name 
    string fileName = @"A:\LongPath\CanBe\AnyPathYou\SpecifyHere.txt"; 

    // Find last '\' character 
    int i = fileName.LastIndexOf('\\'); 

    string tokenRight = fileName.Substring(i, fileName.Length - i); 
    string tokenCenter = @"\..."; 
    string tokenLeft = fileName.Substring(0, MAX_WIDTH-(tokenRight.Length + tokenCenter.Length)); 

    string shortFileName = tokenLeft + tokenCenter + tokenRight; 
4

Ecco quello che uso. Crea graziosamente puntini di sospensione nel mezzo di un percorso e consente anche di specificare qualsiasi lunghezza o delimitatore.

Nota questo è un metodo di estensione in modo da poter utilizzare in questo modo `"c:\path\file.foo".EllipsisString()

dubito che è necessario il ciclo while, in realtà probabilmente non, ero troppo occupato per testare correttamente

public static string EllipsisString(this string rawString, int maxLength = 30, char delimiter = '\\') 
    { 
     maxLength -= 3; //account for delimiter spacing 

     if (rawString.Length <= maxLength) 
     { 
      return rawString; 
     } 

     string final = rawString; 
     List<string> parts; 

     int loops = 0; 
     while (loops++ < 100) 
     { 
      parts = rawString.Split(delimiter).ToList(); 
      parts.RemoveRange(parts.Count - 1 - loops, loops); 
      if (parts.Count == 1) 
      { 
       return parts.Last(); 
      } 

      parts.Insert(parts.Count - 1, "..."); 
      final = string.Join(delimiter.ToString(), parts); 
      if (final.Length < maxLength) 
      { 
       return final; 
      } 
     } 

     return rawString.Split(delimiter).ToList().Last(); 
    } 
Problemi correlati