Эквивалентный код CreateObject в C#
У меня есть код в VB6. Может кто-нибудь сказать мне, как написать это в C#
, Этот код ниже:
Set Amibroker = CreateObject("Broker.Application")
Set STOCK = Amibroker.Stocks.Add(ticker)
Set quote = STOCK.Quotations.Add(stInDate)
quote.Open = stInOpen
quote.High = stInHigh
quote.Low = stInlow
quote.Close = stInYcp
quote.Volume = stInVolume
Set STOCK = Nothing
Set quote = Nothing
Что эквивалентно CreateObject
в C#? Я пытаюсь добавить ссылки на com-объект, но не могу найти ни один com-объект как Broker.Application или amibroker.
4 ответа
Если вы используете.net 4 или более позднюю версию и, следовательно, можете использовать dynamic
Вы можете сделать это довольно просто. Вот пример, который использует интерфейс автоматизации Excel.
Type ExcelType = Type.GetTypeFromProgID("Excel.Application");
dynamic ExcelInst = Activator.CreateInstance(ExcelType);
ExcelInst.Visible = true;
Если вы не можете использовать динамический, тогда это намного более грязно.
Type ExcelType = Type.GetTypeFromProgID("Excel.Application");
object ExcelInst = Activator.CreateInstance(ExcelType);
ExcelType.InvokeMember("Visible", BindingFlags.SetProperty, null,
ExcelInst, new object[1] {true});
Попытка сделать очень многое из этого лишит вас жизненной силы.
COM намного проще, если вы можете использовать раннюю привязку, а не позднюю, как показано выше. Вы уверены, что не можете найти правильную ссылку для COM-объекта?
Если вы используете.NET Framework 4.0 и выше, вы можете использовать этот шаблон:
public sealed class Application: MarshalByRefObject {
private readonly dynamic _application;
// Methods
public Application() {
const string progId = "Broker.Application";
_application = Activator.CreateInstance(Type.GetTypeFromProgID(progId));
}
public Application(dynamic application) {
_application = application;
}
public int Import(ImportType type, string path) {
return _application.Import((short) type, path);
}
public int Import(ImportType type, string path, string defFileName) {
return _application.Import((short) type, path, defFileName);
}
public bool LoadDatabase(string path) {
return _application.LoadDatabase(path);
}
public bool LoadLayout(string path) {
return _application.LoadLayout(path);
}
public int Log(ImportLog action) {
return _application.Log((short) action);
}
public void Quit() {
_application.Quit();
}
public void RefreshAll() {
_application.RefreshAll();
}
public void SaveDatabase() {
_application.SaveDatabase();
}
public bool SaveLayout(string path) {
return _application.SaveLayout(path);
}
// Properties
public Document ActiveDocument {
get {
var document = _application.ActiveDocument;
return document != null ? new Document(document) : null;
}
}
public Window ActiveWindow {
get {
var window = _application.ActiveWindow;
return window != null ? new Window(window) : null;
}
}
public AnalysisDocs AnalysisDocs {
get {
var analysisDocs = _application.AnalysisDocs;
return analysisDocs != null ? new AnalysisDocs(analysisDocs) : null;
}
}
public Commentary Commentary {
get {
var commentary = _application.Commentary;
return commentary != null ? new Commentary(commentary) : null;
}
}
public Documents Documents {
get {
var documents = _application.Documents;
return documents != null ? new Documents(documents) : null;
}
}
public string DatabasePath {
get { return _application.DatabasePath; }
}
public bool Visible {
get { return _application.Visible != 0; }
set { _application.Visible = value ? 1 : 0; }
}
public string Version {
get { return _application.Version; }
}
}
}
Затем вы должны обернуть все классы автоматизации OLE AmiBroker. Например, обернуть комментарий класса:
public sealed class Commentary : MarshalByRefObject {
// Fields
private readonly dynamic _commentary;
// Methods
internal Commentary(dynamic commentary) {
_commentary = commentary;
}
public void Apply() {
_commentary.Apply();
}
public void Close() {
_commentary.Close();
}
public bool LoadFormula(string path) {
return _commentary.LoadFormula(path);
}
public bool Save(string path) {
return _commentary.Save(path);
}
public bool SaveFormula(string path) {
return _commentary.SaveFormula(path);
}
}
Вот фрагмент кода C#, который я использовал для автоматизации Amibroker (с тех пор, как я пошел по этому пути). Вам нужно будет сослаться на System.Runtime.Interopservices
System.Type objType = System.Type.GetTypeFromProgID("Broker.Application");
dynamic comObject = System.Activator.CreateInstance(objType);
comObject.Import(0, fileName, "default.format");
comObject.RefreshAll();
Однако ввод точки не вызовет внутренние методы comObject.
Все, что я могу сказать об этом методе - это работает, как обаяние, но держись подальше от него, как сказал Дэвид. Я получил вдохновение для этого метода от:
http://www.codeproject.com/Articles/148959/How-the-new-C-dynamic-type-can-simplify-access-to
Для другого угла атаки, вы можете проверить (я думаю, что это раннее связывание):
http://adamprescott.net/2012/04/05/net-vb6-interop-tutorial/
Надеюсь, что хоть что-то из этого поможет вам. Я использовал оба этих метода с Amibroker и C#, но в итоге я оставил их позади. COM и Amibroker не очень хорошо смешиваются. Даже TJ так говорит.
В любом случае, удачи.
ami2py прочитает данные AmiBroker в python. Текущая версия .0.8.1 ПРЕДУПРЕЖДЕНИЕ. Она обеспечивает только дневное разрешение данных.
Следующие несколько строк кода будут читать символ из AmiBroker в pandas df
import pandas
import ami2py
folder='C:/Program Files/AmiBroker/Databases/StockCharts'
symbol='indu'
df = pandas.DataFrame()
symbolData = ami2py.AmiDataBase(folder).get_dict_for_symbol(symbol)
for z in ['Year', 'Month', 'Day', 'Open', 'High', 'Low', 'Close', 'Volume'] :
df[symbol+':'+z] = symbolData[z]
print(df.describe())