У меня есть приложение, которое вызывает подпрограмму в сценарии. Я передаю DataSet этой процедуре - и она создает Datatable - дает ей имя - а затем использует процедуру DataTable.COPY() для копирования уже существующей таблицы данных (назовем ее X) в новую, которую я создал в CS- Процедура сценария.
Однако, когда сценарий завершается и возвращается в вызывающую программу, таблица данных все еще существует, но в ней нет ни столбцов, ни строк... ?? Тем не менее, они существовали в сценарии (для проверки я использовал MessageBox.Show)
C# Application
Creates DataSet - and DataTable X
Call CS-Script
Creates DataTable Y - and adds to the Dataset that was passed into this script routine
Runs the Copy() method of the datatable to duplicate Table X into Y
I check the Cols and Rows - and they are what they should be (6 Cols and ~2000 rows)
Call Passes back to my C# application
DataTable Y still exists - but no Cols or Rows ???
Странно то, что у меня есть другие сценарии, которые принимают DataSet и изменяют DataTable (добавляют столбец и помещают в него значения) – и они в порядке, когда вызов возвращается в приложение C# из сценария.
Кто-нибудь знает, почему я теряю определения столбцов и строк из метода COPY(), вызываемого в процедуре CS-SCript?
Сценарий, который я вызываю:
Это сценарий, который я вызываю из приложения C#.
using System;
using System.Data;
using System.IO;
using CSScript_Types;
using System.Windows.Forms;
using InSight;
// This is the class that does the Real work of the CS Script After Query work
public class AfterTableScripts : iAfterTableStuff
{
// This is the generic routine that is called from InSights Into Data
// Return value is string so that we can handle Bool, string, number, etc.
public CSScriptReturnValueClass AfterTableProcess(DataSet CurrDataSet, string CurrTableName, Form_InSightsMain MainForm)
{
CSScriptReturnValueClass ReturnRec = new CSScriptReturnValueClass();
try
{
// Here is the code to be run after the Table is created in the dataset
DataTable QHRInvoices = CurrDataSet.Tables["QHRInvoices"];
DataTable DupTable = CurrDataSet.Tables.Add("DupsTable");
DupTable = QHRInvoices.Copy();
DupTable.TableName = "DupsTable";
// Now Setup the Return Value
ReturnRec.Success = true;
ReturnRec.ReturnValue = "";
ReturnRec.ErrorMsg = "";
}
catch (Exception Ex)
{
// Now Setup the Return Value
ReturnRec.Success = false;
ReturnRec.ReturnValue = "";
ReturnRec.ErrorMsg = Ex.Message;
}
return ReturnRec;
}
}
А вот вызывающий код в приложении C#:
CSScriptReturnValueClass ReturnValue = new CSScriptReturnValueClass();
//string ReturnValue;
dynamic AfterTableScript = CSScript.Evaluator.LoadCode(CurrCode);
ReturnValue = AfterTableScript.AfterTableProcess(CurrDataSet, CurrTableName, MainForm);
if (ReturnValue.Success)
{
return true;
}
else
{
// Need to Change this to a Logging routine
FlexibleMessageBox.Show("Failure of CS Script: Error: " + ReturnValue.ErrorMsg, "CodeRunAfterQuery - Message");
return false;
}
Подробнее здесь: https://stackoverflow.com/questions/792 ... n-to-c-sha
CS-Script — интересная проблема (отсутствуют записи/столбцы при возврате в программу на C#) ⇐ C#
Место общения программистов C#
1733267036
Anonymous
У меня есть приложение, которое вызывает подпрограмму в сценарии. Я передаю DataSet этой процедуре - и она создает Datatable - дает ей имя - а затем использует процедуру DataTable.COPY() для копирования уже существующей таблицы данных (назовем ее X) в новую, которую я создал в CS- Процедура сценария.
Однако, когда сценарий завершается и возвращается в вызывающую программу, таблица данных все еще существует, но в ней нет ни столбцов, ни строк... ?? Тем не менее, они существовали в сценарии (для проверки я использовал MessageBox.Show)
C# Application
Creates DataSet - and DataTable X
Call CS-Script
Creates DataTable Y - and adds to the Dataset that was passed into this script routine
Runs the Copy() method of the datatable to duplicate Table X into Y
I check the Cols and Rows - and they are what they should be (6 Cols and ~2000 rows)
Call Passes back to my C# application
DataTable Y still exists - but no Cols or Rows ???
Странно то, что у меня есть другие сценарии, которые принимают DataSet и изменяют DataTable (добавляют столбец и помещают в него значения) – и они в порядке, когда вызов возвращается в приложение C# из сценария.
Кто-нибудь знает, почему я теряю определения столбцов и строк из метода COPY(), вызываемого в процедуре CS-SCript?
Сценарий, который я вызываю:
Это сценарий, который я вызываю из приложения C#.
using System;
using System.Data;
using System.IO;
using CSScript_Types;
using System.Windows.Forms;
using InSight;
// This is the class that does the Real work of the CS Script After Query work
public class AfterTableScripts : iAfterTableStuff
{
// This is the generic routine that is called from InSights Into Data
// Return value is string so that we can handle Bool, string, number, etc.
public CSScriptReturnValueClass AfterTableProcess(DataSet CurrDataSet, string CurrTableName, Form_InSightsMain MainForm)
{
CSScriptReturnValueClass ReturnRec = new CSScriptReturnValueClass();
try
{
// Here is the code to be run after the Table is created in the dataset
DataTable QHRInvoices = CurrDataSet.Tables["QHRInvoices"];
DataTable DupTable = CurrDataSet.Tables.Add("DupsTable");
DupTable = QHRInvoices.Copy();
DupTable.TableName = "DupsTable";
// Now Setup the Return Value
ReturnRec.Success = true;
ReturnRec.ReturnValue = "";
ReturnRec.ErrorMsg = "";
}
catch (Exception Ex)
{
// Now Setup the Return Value
ReturnRec.Success = false;
ReturnRec.ReturnValue = "";
ReturnRec.ErrorMsg = Ex.Message;
}
return ReturnRec;
}
}
А вот вызывающий код в приложении C#:
CSScriptReturnValueClass ReturnValue = new CSScriptReturnValueClass();
//string ReturnValue;
dynamic AfterTableScript = CSScript.Evaluator.LoadCode(CurrCode);
ReturnValue = AfterTableScript.AfterTableProcess(CurrDataSet, CurrTableName, MainForm);
if (ReturnValue.Success)
{
return true;
}
else
{
// Need to Change this to a Logging routine
FlexibleMessageBox.Show("Failure of CS Script: Error: " + ReturnValue.ErrorMsg, "CodeRunAfterQuery - Message");
return false;
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79249219/cs-script-an-interesting-problem-records-columns-missing-upon-return-to-c-sha[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия