SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 2823|回复: 10
打印 上一主题 下一主题

SAS如何在VB中调用?

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2005-4-5 09:02:47 | 只看该作者

SAS如何在VB中调用?

我有一个SAS程序,想用VB界面中输入相关的变量,在SAS中应用,有没有办法把SAS变成一个可执行文件,用VB输入相关变量。谢谢各位大侠!!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2005-4-5 12:53:14 | 只看该作者

to huonulhg

SAS程序不能被编译成exe文件或者dll文件被VB直接调用,只能通过接口SAS/IT模块来实现VB对SAS的访问和调用。
先确定你有没有SAS/IT模块,如果有再找几篇关于VB调用SAS方法介绍的SUGI文章看看,很快就入门了。网上这样的文章还是不少的。
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2005-4-5 13:25:27 | 只看该作者

请问我如何能知道是否安装了IT模块

请问我如何能知道是否安装了IT模块
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2005-4-7 12:32:31 | 只看该作者

to huonulhg

如果安装了以后在VB中选择“库引用”菜单,可以看到
Microsoft ActiveX Data Objects 2.5 Library
SAS: Integrated Object Model (IOM) 1.0 Type Library
SASWorkSpaceManager 1.0 Type Library
[code:c85fe]      Dim obWS As SAS.Workspace
      Dim obWSM As New SASWorkspaceManager.WorkspaceManager
      
      Sub Form_Load()
      Dim obConn As New ADODB.Connection
      Dim obRS As New ADODB.Recordset
      Dim errorString As String
      
      Rem start the SAS session
      Set obWS = obWSM.Workspaces.CreateWorkspaceByServer("Local", _
                 VisibilityProcess, Nothing, "", "", errorString)
      
      Rem submit some SAS code
      obWS.LanguageService.Submit _
           "data a; do x=1 to 10; y=10*x; output; end; run;"
      
      Rem open an ADO connection to the data set
      Dim connString As String
      connString = "provider=sas.iomprovider.1; SAS Workspace ID=" _
                   + obWS.UniqueIdentifier
      obConn.Open connString
      obRS.Open "work.a", obConn, adOpenStatic, adLockReadOnly, _
                adCmdTableDirect
      
      Rem write the table as html (visible in Word with tags)
      obRS.MoveFirst
      Dim sTable As String
      sTable = "<TABLE BORDER=0><TBODY><TR><TD class=Data>"
      Selection.TypeText sTable
      sTable = obRS.GetString(, , "</TD><TD class=Data>", _
      "</TD></TR><TR><TD class=Data>")
      Selection.TypeText sTable
      sTable = "</TD></TR></TBODY></TABLE>"
      Selection.TypeText sTable
      
      Rem tidy-up
      obRS.Close
      obConn.Close
      obWS.Close
      
      End Sub[/code:c85fe]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
5#
 楼主| 发表于 2005-4-7 13:29:37 | 只看该作者

Thx

谢谢版主!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
6#
 楼主| 发表于 2005-5-12 11:11:51 | 只看该作者

谢谢版主

版主高人,解决了困惑我很长时间的问题。谢谢!!!
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
7#
 楼主| 发表于 2005-5-14 05:20:42 | 只看该作者

IT模块

我现在有SAS 8.2,里面只有基本的那些模块
想问一下IT模块在哪里才能下载到
多谢了
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
8#
 楼主| 发表于 2005-5-23 20:26:23 | 只看该作者

Re: to huonulhg

请问在调试给出的例程是出现“the requested funcrtion was not performed due to an invalid or expired product license”错误信息,但从开始菜单运行sas时却能正常运行,不知什么原因,我用的是8.2版本

是不是许可不对?到哪能下到最新的许可?

另外用VB调用SAS的书能否介绍一下,SUGI文章是什么意思?
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
9#
 楼主| 发表于 2005-5-30 11:47:35 | 只看该作者

to xuxianhai

的确是没有正确的许可。

我在国内从没有看到过专门介绍VB调用SAS的书籍,我想看看SUGI的文章是很有帮助的、很现实的。
<!-- m --><a class="postlink" href="http://support.sas.com/usergroups/sugi/intro.html">http://support.sas.com/usergroups/sugi/intro.html</a><!-- m -->
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
10#
 楼主| 发表于 2005-5-30 21:41:22 | 只看该作者

谢谢版主!

谢谢版主! 我会更努力的,谢谢你的帮助与支持!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2025-5-6 21:25 , Processed in 0.071924 second(s), 21 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表