powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Программирование [игнор отключен] [закрыт для гостей] / C#
4 сообщений из 4, страница 1 из 1
C#
    #36996825
Игорь86
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Всем привет.

Подскажите, пожалуйста.

Вот кусок кода
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
 OracleCommand comm = new OracleCommand(commsql, conn);

                OracleDataReader dr = comm.ExecuteReader();

                StreamWriter newfile = new StreamWriter(filecreate);

                if (dr.HasRows)
                {
                    
                    while (dr.Read())
                    {
                        string datadr = dr.GetString( 0 );
                        newfile.WriteLine(datadr);
                    }

                    

                    newfile.Close();
                    newfile.Dispose();
                    dr.Close();
                    dr.Dispose();
                }

                else
                {
                    this.Close();
                    this.Dispose();
                }

При чтении РИДЕРОМ идет построчная запись в файл, и когда записывается последняя строка, то курсор переходит на новую строку. Таким образом в файле есть последняя пустая строка.

Как ее удалить?
...
Рейтинг: 0 / 0
C#
    #36997704
Gatman
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
как вариант
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
........................
StreamWriter newfile = new StreamWriter(filecreate);
if (dr.Read())
                {
                    newfile.Write(dr.GetString(0));
                    while (dr.Read())
                    {
                        newfile.WriteLine();
                        string datadr = dr.GetString(0);
                        newfile.Write(datadr);
                    }
......................
Или взять у newfile BaseStream и сделать ему SetLength на Length - NewLine.Length
...
Рейтинг: 0 / 0
C#
    #36997843
Игорь86
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Gatmanкак вариант
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
........................
StreamWriter newfile = new StreamWriter(filecreate);
if (dr.Read())
                {
                    newfile.Write(dr.GetString(0));
                    while (dr.Read())
                    {
                        newfile.WriteLine();
                        string datadr = dr.GetString(0);
                        newfile.Write(datadr);
                    }
......................
Или взять у newfile BaseStream и сделать ему SetLength на Length - NewLine.Length

Спасибо, пока разбирался, примерно так же и сделал.
...
Рейтинг: 0 / 0
C#
    #37001114
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Игорь86Спасибо, пока разбирался, примерно так же и сделал.

Всё ещё проще:

Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
using (var command = new OracleCommand(commsql, conn))
{
    var sb = new StringBuilder();
    using (var reader = command.ExecuteReader())
    {
        while (reader.Read())
            sb.AppendLine(reader.GetString(0));
        File.WriteAllText(filecreate, sb.ToString().TrimEnd(Environment.NewLine.ToCharArray()));
    }
}
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / Программирование [игнор отключен] [закрыт для гостей] / C#
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]