乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 20|回复: 1

[VBA]批量替换图块

[复制链接]

20

主题

115

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
195
发表于 2005-11-23 19:44:00 | 显示全部楼层 |阅读模式
我在做一个块批量替换的程序。原先图中有二、三十种块,现在用其他的图块来替换,如GC120-->10211、GC119-->12111。这种对应关系我已经在ACCESS数据库中已经建立,现在就是在考虑程序运行效率的问题。我想了两种方法:
1)一次性将对应关系读入数组中保存,这样就只需访问数据库一次就行。替换时再从数组中找对应关系。
2)每次都从数据库中去找对应关系。
请问版主,上面两种方法,哪种应该会运行快点?还有没有其他更好的方法?
回复

使用道具 举报

124

主题

837

帖子

9

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1333
发表于 2005-11-23 19:57:00 | 显示全部楼层
你可以考虑做成INI文件,格式
[SECTION]
GC120=10211
GC119=12111
GC121=12112
GC122=12113
GC123=12114
然后用API函数读取.
VB读取INI文件程序:
Declare Function GetPrivateProfileString Lib "kernel32" Alias "GetPrivateProfileStringA" _
    (ByVal lpApplicationName As String, _
     ByVal lpKeyName As Any, ByVal lpDefault As String, _
     ByVal lpReturnedString As String, ByVal nSize As Long, _
     ByVal lpFileName As String) As Long
Public Function ReadIni(ByVal file As String, ByVal section As String, _
ByVal key As String, ByVal default As String) As String
    Dim x As Long
    Dim sSection As String, sEntry As String, sDefault As String
    Dim sRetBuf As String, iLenBuf As Integer, sFileName As String
   
    'Six arguments
    sSection$ = section
    sEntry$ = key
    sDefault$ = default
    sRetBuf$ = String$(256, 0)  '256 null character
    iLenBuf% = Len(sRetBuf$)
    sFileName$ = file
   
    'function will return a value of 12 in this case
    x = GetPrivateProfileString(sSection$, sEntry$, sDefault$, sRetBuf$, iLenBuf%, sFileName$)
   
    'sValue$ will contain the string 'PACKARD BELL'
    sValue$ = Left$(sRetBuf$, x)
   
    'return value
    ReadIni = sValue$
   
End Function
Sub Test_ReadIni()
    MsgBox ReadIni("d:\test.ini", "TEST", "2", "null")
End Sub
文件d:\test.ini的内容:
[test]
1=hello
2=world
3=!
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-4 19:55 , Processed in 0.812954 second(s), 56 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表