Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.57/7: Рейтинг темы: голосов - 7, средняя оценка - 4.57
17 / 18 / 0
Регистрация: 01.02.2012
Сообщений: 182

Глобальный объект класс

28.01.2013, 01:40. Показов 1519. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть код
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
class Program
    {
        static void Main(string[] args)
        {
 
Excel.Application xlApp;
Excel.Workbook xlWorkBook;
Excel.Worksheet xlWorkSheet;
object misValue = System.Reflection.Missing.Value;
xlApp = new Excel.Application();
xlWorkBook = xlApp.Workbooks.Open("C:/1.xls");
xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1);
string sheet = xlApp.ActiveSheet.Name;
xlWorkBook.Close(true, misValue, misValue);
xlApp.Quit();
System.Data.OleDb.OleDbConnection MyConnection;
System.Data.DataSet DtSet;
System.Data.OleDb.OleDbDataAdapter MyCommand;
MyConnection = new System.Data.OleDb.OleDbConnection(string.Format(@"provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};
Extended Properties=Excel 8.0;", "C:/1.xls"));
 
MyCommand = new System.Data.OleDb.OleDbDataAdapter(string.Format("select * from [{0}$]", sheet), MyConnection);
DtSet = new System.Data.DataSet();
DataTable ordersTable = DtSet.Tables.Add("0");
MyCommand.Fill(DtSet.Tables["0"]);
 
}
    }
Коротко. Этот код создаёт датасет и забивает в него из файла Excel всё что там есть.

Суть проблемы.

Допустим я создаю в классе метод
C#
1
2
3
4
5
public int what()
        {
            Console.WriteLine(DtSet.Tables[0].Rows[1]["A1"].ToString());
            return 0;
        }
Пишет что Элемент "DtSet" не существует в текущем контексте.

Методов будет много, которые должны использовать 1 общий датасет. Помогите реализовать
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.01.2013, 01:40
Ответы с готовыми решениями:

Глобальный объект
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using...

Глобальный объект
Как сделать такое: при запуске программы (т.е. появление Главной формы) я создаю объект (коллекция) на основе моего public класса. И этотот...

Глобальный объект
Добрый день. Подскажите, как надо объявить класс data, так, что бы потом в начале документа сделать $data = new data и чтоб этот объект...

2
Эксперт JavaЭксперт С++
 Аватар для M128K145
8384 / 3617 / 419
Регистрация: 03.07.2009
Сообщений: 10,709
28.01.2013, 02:09
Вам необходимо сделать переменную статическим полем класса. Метод what также необходимо сделать статическим.
Т.е. код должен выглядеть примерно так
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
class Program
{
    static System.Data.DataSet DtSet;
    static void Main (string[] args)
    {
        
        Excel.Application xlApp;
        Excel.Workbook xlWorkBook;
        Excel.Worksheet xlWorkSheet;
        object misValue = System.Reflection.Missing.Value;
        xlApp = new Excel.Application ();
        xlWorkBook = xlApp.Workbooks.Open ("C:/1.xls");
        xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item (1);
        string sheet = xlApp.ActiveSheet.Name;
        xlWorkBook.Close (true, misValue, misValue);
        xlApp.Quit ();
        System.Data.OleDb.OleDbConnection MyConnection;
        System.Data.OleDb.OleDbDataAdapter MyCommand;
        MyConnection = new System.Data.OleDb.OleDbConnection (string.Format (@"provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};
Extended Properties=Excel 8.0;", "C:/1.xls"));
        
        MyCommand = new System.Data.OleDb.OleDbDataAdapter (string.Format ("select * from [{0}$]", sheet), MyConnection);
        DtSet = new System.Data.DataSet ();
        DataTable ordersTable = DtSet.Tables.Add ("0");
        MyCommand.Fill (DtSet.Tables["0"]);
        
    }
    public static int what ()
    {
        Console.WriteLine (DtSet.Tables[0].Rows[1]["A1"].ToString ());
        return 0;
    }
}
1
17 / 18 / 0
Регистрация: 01.02.2012
Сообщений: 182
28.01.2013, 04:55  [ТС]
M128K145, вот что мне пишет.
DataTable ordersTable = DtSet.Tables.Add("0"); --- Ссылка на объект не указывает на экземпляр объекта.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.01.2013, 04:55
Помогаю со студенческими работами здесь

Глобальный объект
Есть у меня приложение с формой Win Forms(CLR) Ну у меня весь код соответственно в .h файле. Как там объявить вектор, что-бы его можно было...

Глобальный объект
Как сделать, чтобы я создал объект, и его видел весь файл? Суть в том, что в конструктор я хочу передать аргумент. Или нужно сделать...

Глобальный объект
Можете объяснить такие вещи: 1)Название объекта в каждой среде разное?(то есть в ecmascript-object,в браузере-window) 2)Доступ к этим...

Глобальный объект класса
Добрый вечер всем!) Вообщем суть такая: пишу статическую библиотеку, которая состоит из кучи файлов. Есть класс, конструктор которого...

Динамический глобальный объект.
Здравствуйте. Пишу Auto-Clicker . Текущая версия содержит заранее созданный массив объектов класса "TClickBase" в каждом объекте...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru