Разбор tnsnames.ora в Visual C # 2008 - PullRequest
3 голосов
/ 07 августа 2009

Как проанализировать файл tnsnames.ora с помощью Visual C # (выпуск Visual Studio 2008 Express), чтобы получить имена tnsname? Например, мой файл tnsnames.ora содержит

ORCL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = shaman)(PORT = 1521))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )
BILL =
  (DESCRIPTION =
    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.10.58)(PORT = 1522))
    (CONNECT_DATA =
      (SERVER = DEDICATED)
      (SERVICE_NAME = orcl)
    )
  )

Как я могу разобрать этот файл, чтобы получить TNSNAMES (т. Е. ORCL, BILL и т. Д.). Простите, если этот вопрос звучит слишком очевидно, я учусь и пробую свои силы в C #

Ответы [ 3 ]

3 голосов
/ 07 августа 2009

Прежде всего, вам понадобится правила синтаксиса для этого файла .

Возможно, для этого есть хак, но я бы лично выбрал полный анализатор, например ANTLR в сочетании с правильной грамматикой (полный список грамматик ANTLR можно найти здесь ).

1 голос
/ 29 ноября 2011
public List<string> ReadTextFile(string FP)
{

    string inputString;
    List<string> List = new List<string>();

    try
    {
        StreamReader streamReader = File.OpenText(FP.Trim()); // FP is the filepath of TNS file

        inputString = streamReader.ReadToEnd();
        string[] temp = inputString.Split(new string[] {Environment.NewLine},StringSplitOptions.None);

        for (int i = 0; i < temp.Length ;i++ )
        {
            if (temp[i].Trim(' ', '(').Contains("DESCRIPTION"))
            {                   
                string DS = temp[i-1].Trim('=', ' ');
                List.Add(DS);
            }             

        }
        streamReader.Close();
    }
    catch (Exception EX)
    {
    }


    return List;

}
0 голосов
/ 27 декабря 2010

вместе с тем, что предоставил Сатья, создайте метод:

StringBuilder strTns = new StringBuilder ();

foreach ( var fileLine in System.IO.File.ReadAllLines(fiTNS.FullName ) )
{
    if ( (fileLine.Length > 0 
           && fileLine.Trim().Substring(0,1) != "#" 
          )
          && ( fileLine.Length > 0 
                && fileLine.Trim ().Substring (0,1) != "/" 
              )
        )

        {
           strTns.AppendFormat("{0}{1}", fileLine, Environment.NewLine);
        }
}

//TNSNamesValues = System.IO.File.ReadAllText (fiTNS.FullName).ToString ().Replace ("\n", "" ).Replace ("\r", "");
String[] splitSeparator = LoadTNSNames (OracleHomeRegistryKey).ToArray ();
String[] TNS = strTns.ToString().Split (splitSeparator, StringSplitOptions.None);
...