|
我需要用VBA调用DLL函数,并用EXCEL实现操作。但不知道如何写代码,希望大神指点!跪谢了!
下面是DLL的函数说明,
//1.API均是ttda.dll文件的导出函数,包括以下函数:
// 8个函数:
// void OpenTdx();//打开
// void CloseTdx();//关闭
// int Logon(char* IP, short Port, char* Version, short YybID, char* AccountNo,char* TradeAccount, char* JyPassword, char* TxPassword, char* ErrInfo);//登录帐号
// void Logoff(int ClientID);//注销
// void QueryData(int ClientID, int Category, char* Result, char* ErrInfo);//查询各类数据
// void SendOrder(int ClientID, int Category ,int PriceType, char* Gddm, char* Zqdm , float Price, int Quantity, char* Result, char* ErrInfo);//执行
// void CancelOrder(int ClientID, char* ExchangeID, char* hth, char* Result, char* ErrInfo);//撤销
// void GetQuote(int ClientID, char* Zqdm, char* Result, char* ErrInfo);//获取数据
/// <summary>
/// 账户登录
/// </summary>
/// <param name="IP">服务器IP</param>
/// <param name="Port">服务器端口</param>
/// <param name="Version">版本号</param>
/// <param name="YybID">代码, 普通 “0” 高级“3” </param>
/// <param name="AccountNo">登录账号</param>
/// <param name="TradeAccount">执行账号</param>
/// <param name="JyPassword">密码</param>
/// <param name="TxPassword">备用密码</param>
/// <param name="ErrInfo">此API执行返回后,如果出错,保存了错误信息说明。一般要分配256字节的空间。没出错时为空字符串。</param>
/// <returns>客户端ID,失败时返回-1</returns>
/// int Logon(char* IP, short Port, char* Version,short YybID, char* AccountNo,char* TradeAccount, char* JyPassword, char* TxPassword, char* ErrInfo);
typedef int(__stdcall* LogonDelegate)( char* IP, short Port, char* Version,short YybID, char* AccountNo, char* TradeAccount, char* JyPassword, char* TxPassword, char*
ErrInfo);
/// <summary>
/// 账户注销
/// </summary>
/// <param name="ClientID">客户端ID</param>
/// void Logoff(int ClientID);
typedef void(__stdcall* LogoffDelegate)(int ClientID);
/// <summary>
/// 查询各种数据
/// </summary>
/// <param name="ClientID">客户端ID</param>
/// <param name="Category">表示查询信息的种类,0库存 1数量 2当日采购计划 3当日入库 4可退货 5申请人 6预支 7预还 8可还</param>
/// <param name="Result">此API执行返回后,Result内保存了返回的查询数据, 形式为表格数据,行数据之间通过\n字符分割,列数据之间通过\t分隔。一般要分配1024*1024字节的空间。出错时为
空字符串。</param>
/// <param name="ErrInfo">同Logon函数的ErrInfo说明</param>
/// void QueryData(int ClientID, int Category, char* Result, char* ErrInfo);
typedef void(__stdcall* QueryDataDelegate)(int ClientID, int Category, char* Result, char* ErrInfo);
/// <summary>
/// 下单采购
/// </summary>
/// <param name="ClientID">申请人ID</param>
/// <param name="Category">表示委托的种类,0买入 1卖出 2融资买入</param>
/// <param name="PriceType">表示报价方式 0限价买入 1折价买入 2溢价买入
/// <param name="Gddm">申请人编码</param>
/// <param name="Zqdm">货物代码</param>
/// <param name="Price">下单价格</param>
/// <param name="Quantity">下单数量</param>
/// <param name="Result">此API执行返回后,Result内保存了返回的查询数据, 形式为表格数据,行数据之间通过\n字符分割,列数据之间通过\t分隔。一般要分配1024*1024字节的空间。出错时为
空字符串。</param>,其中含有委托编号数据</param>
/// <param name="ErrInfo">此API执行返回后,如果出错,保存了错误信息说明。一般要分配256字节的空间。没出错时为空字符串。</param>
/// void SendOrder(int ClientID, int Category ,int PriceType, char* Gddm, char* Zqdm , float Price, int Quantity, char* Result, char* ErrInfo);
typedef void(__stdcall* SendOrderDelegate)(int ClientID, int Category, int PriceType, char* Gddm, char* Zqdm, float Price, int Quantity, char* Result, char* ErrInfo);
|
|