1 / 1 / 2
Регистрация: 02.10.2013
Сообщений: 76

Открыть txt файл в Excel и сохранить в xls формате

27.12.2014, 05:47. Показов 5942. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
мне нужно данные из txt файла пересохранить в .xls формате. тем много, но конкретных шагов для ламера, что где кликнуть, как куда что импортировать я просидев до 4-30 не нашел((
в нете нашел идею: нужно открыть txt файл (с \t разделителями) в эксель и сохранить .xls формате.

там приводится код:
C#
1
2
xlWorkBook = xlApp.Workbooks.Open(f, 0, true, 5, "", "", true, Microsoft.Office.Interop.Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, 1, 0); 
xlWorkBook.SaveAs(filename + ".xls", Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
но при вставке его в мой проект с одной кнопкой и опенфайлдиалогом выдает ошибку, что xlWorkBook, xlApp и т.д. отсутствует в текущем контексте
Microsoft Excel Object Library импортировал в референсес, подскажите пожалуйста что я делаю не правильно?
C#
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
29
30
31
32
33
34
35
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Excel = Microsoft.Office.Interop.Excel;
 
namespace TXT_TO_XLS
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            if(openFileDialog1.ShowDialog() == DialogResult.OK)
            { 
                for (int i = 0; i < openFileDialog1.FileNames.Length; i++)
              
                {
                    xlWorkBook = xlApp.Workbooks.Open(openFileDialog1.FileNames[i], 0, true, 5, "", "", true, Microsoft.Office.Interop.Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, 1, 0);
                    xlWorkBook.SaveAs(openFileDialog1.FileNames[i] + ".xls", Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
 
                }
            }
        }
    }
}
Заранее спасибо за любые подсказки!
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.12.2014, 05:47
Ответы с готовыми решениями:

Как сохранить файл в формате excel?
Или подскажите где копать?

Как открыть файл xlsx и сохранить в txt?
Написать консольное windows приложение на Visual C++ со следующим функционалом: - на вход программы (в виде параметров командной строки)...

Сохранить csv в формате xls
Подскажите, пожалуйста, как в Excel сохранить открытый csv-файл как xls? У меня открывается корректно, но сохраняется неправильно, как...

6
 Аватар для chumich
2081 / 1239 / 464
Регистрация: 20.12.2014
Сообщений: 3,234
27.12.2014, 09:46
Будет ваш код преобразовывать и сохранять - не знаю, но, чтобы xlWorkBook и xlApp присутствовали в текущем контексте, в цикл нужно добавить:
C#
1
2
3
4
5
6
private Excel.Application xlApp;
        private Excel.Workbook xlWorkBook;
        xlApp = new Excel.Application ();
        xlApp.Visible = true; // это необязательно, но можно использовать, чтобы увидеть в том ли виде открылся документ
        //далее как у вас
        xlWorkBook = xlApp.Workbooks.Open( ... ); // ... - ваши параметры и т. д.
1
1 / 1 / 2
Регистрация: 02.10.2013
Сообщений: 76
27.12.2014, 13:36  [ТС]
chumich, спасибо!!! с вашей помощью разобрался
C#
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using Excel = Microsoft.Office.Interop.Excel;
using Microsoft.Office;
using Microsoft.Office.Core;
 
namespace TXT_TO_XLS
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
 
   private Excel.Application xlApp;
   private Excel.Workbook xlWorkBook;
                    
   private void button1_Click(object sender, EventArgs e)
        {
            if(openFileDialog1.ShowDialog() == DialogResult.OK)
            { 
                for (int i = 0; i < openFileDialog1.FileNames.Length; i++)              
                {
                    xlApp = new Excel.Application ();
                    //xlApp.Visible = true; //чтобы увидеть в том ли виде открылся документ                   
                    object misValue = System.Reflection.Missing.Value;
                    xlWorkBook = xlApp.Workbooks.Open(openFileDialog1.FileNames[i], Microsoft.Office.Interop.Excel.XlTextParsingType.xlDelimited);// 0, true, 5, "", "", true, Microsoft.Office.Interop.Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, 1, 0);
                    xlWorkBook.SaveAs(openFileDialog1.FileNames[i] + ".xls", Excel.XlFileFormat.xlWorkbookNormal, misValue, misValue, misValue, misValue, Excel.XlSaveAsAccessMode.xlExclusive, misValue, misValue, misValue, misValue, misValue);
                    xlWorkBook.Close();
                }
            }
        }
    }
}
сейчас разбираюсь как подсчитать количество строк в исходном текстовом файле и конечном экселевском
0
 Аватар для chumich
2081 / 1239 / 464
Регистрация: 20.12.2014
Сообщений: 3,234
27.12.2014, 13:47
Как в исходном посчитать могу подсказать :
C#
1
2
3
4
5
6
7
8
        using System.IO; // добавляем ссылку
        ...
        public string[] Line;
        public int b;                  
        // считываем построчно информацию из файла в массив Line 
        Line = File.ReadAllLines("путь к файлу", Encoding.Default); 
        // вычисляем количество строк в массиве
           b = Line.Length;
1
1 / 1 / 2
Регистрация: 02.10.2013
Сообщений: 76
27.12.2014, 13:53  [ТС]
chumich, спасибо! подскажите, у меня таких файлов будет штук 50-70 и каждый файл не менее 60000 строк, надо ли как-то чистить массив и т.д. чтобы он не засорял память и не тормозил процесс?
или просто что-то вроде Line.clear();
0
 Аватар для chumich
2081 / 1239 / 464
Регистрация: 20.12.2014
Сообщений: 3,234
27.12.2014, 14:03
Честно говоря, такие объемы не обрабатывал, но думаю, что хватит Line.clear().
0
1 / 1 / 2
Регистрация: 02.10.2013
Сообщений: 76
29.12.2014, 13:29  [ТС]
строки в экселевском файле подсчитал, немного простите по дебильному, но работает очень быстро
мож кому пригодится
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
      
// Имя файла
string filename = @"c:\\123.xls"; 
// Строка подключения
string ConnectionString = String.Format("Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 8.0;HDR=No\";Data Source={0}", filename);
// Открываем соединение
DataSet ds = new DataSet("EXCEL");
OleDbConnection cn = new OleDbConnection(ConnectionString);
cn.Open();
// Получаем список листов в файле
DataTable schemaTable = cn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
String xlscount = "h";
// Береме название первого листа
string sheet1 = (string)schemaTable.Rows[0].ItemArray[2];
// Выбираем все данные с листа
string select = String.Format("SELECT COUNT(*) FROM [{0}]", sheet1);
OleDbDataAdapter ad = new OleDbDataAdapter(select, cn);
ad.Fill(ds);
DataTable tb = ds.Tables[0];
DataRow[] result = tb.Select();
foreach (DataRow row in result) //т.к. выбирали функцией COUNT то в цикле будет только одна итерация, как достать данные без цикла не знаю
{ xlscount = (row[0].ToString()); }// xlscount - количество строк в экселе
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.12.2014, 13:29
Помогаю со студенческими работами здесь

Как сохранить созданную таблицу в VBasic-e 6.0 в MSFlexGrid в файл в формате Excel?
Подскажите, как сохранить созданную таблицу в VBasic-e 6.0 в MSFlexGrid в файл в формате Excel.

Открыть, сохранить и закрыть файл Excel
Господа, помогите реализовать данную задачу. Раз в день надо открыть файл exel (при открытии обновятся связи с другими книгами),...

Проблема передачи переменных в сессии при попытке сохранить файл asp в формате excel
Кто-нибудь сталкивался с проблемой передачи переменных в сессии при попытке сохранить файл asp в формате excel? Я пытаюсь передать...

Как в datagridview открыть Excel файл? И сохранить его
Как в datagridview c# открыть Excel файл? И сохранить.

Excel.xls(2003) сохранить как excel.xlsx (2010)
как реализовать: есть файлы Excel2003 *xls надо сохранить их в *xlsx Excel2010 fileExcel.SaveAs() просто перезаписывает его с новым...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru