設(shè)為首頁收藏本站Access中國

Office中國論壇/Access中國論壇

 找回密碼
 注冊

QQ登錄

只需一步,快速開始

快速讀取 TextBox 第 N 行的資料

1970-1-1 08:00| 發(fā)布者: 未知| 查看: 2207| 評論: 0

TextBox 是以 vbCr+vbLf 為分行符號, 如果我們要逐一讀取 TextBox 每一行,
無非是尋找 vbCr+vbLf 的所在位置, 然后取出每一行的字串, 不過這個(gè)方法真
的不快,而且如果我們要讀取第 N 行資料, 還是要從第 1、2、┅N-1 行逐一讀
起, 實(shí)在麻煩。
還好 Windows API 提供有讀取 TextBox 第 N 行的功能, 細(xì)節(jié)如下:

1. API 的聲明:

Const EM_GETLINE = &HC4
Const EM_LINELENGTH = &HC1
Const EM_LINEINDEX = &HBB

Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (
ByVal hWnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As
Any) As Long
Private Declare Sub RtlMoveMemory Lib "KERNEL32" (lpvDest As Any,
lpvSource As Any, ByVal cbCopy As Long)

注:如果以上的聲明放在「一般模塊」底下, 應(yīng)在 Const 之前加上 Public 保留
字, 并且將 Private 保留字去掉。

2. 程序范例:

Sub TB_GetLine(ByVal hWnd As Long, ByVal whichLine As Long, Line As
String)
Dim length As Long, bArr() As Byte, bArr2() As Byte, lc As Long

lc = SendMessage(hWnd, EM_LINEINDEX, whichLine, ByVal 0&)
length = SendMessage(hWnd, EM_LINELENGTH, lc, ByVal 0&)
If length > 0 Then
ReDim bArr(length + 1) As Byte, bArr2(length - 1) As Byte
Call RtlMoveMemory(bArr(0), length, 2)
Call SendMessage(hWnd, EM_GETLINE, whichLine, bArr(0))
Call RtlMoveMemory(bArr2(0), bArr(0), length)
Line = StrConv(bArr2, vbUnicode)
Else
Line = ""
End If
End Sub

' 假設(shè)要讀取 Text1 第 5 行的資料
Dim S As String
Call TB_GetLine( Text1.hWnd, 5, S )
' 傳回值 S 即等于到 5 行的資料
注:TextBox 的行次是從 0 起算。




最新評論

QQ|站長郵箱|小黑屋|手機(jī)版|Office中國/Access中國 ( 粵ICP備10043721號-1 )  

GMT+8, 2025-7-17 00:33 , Processed in 0.064469 second(s), 16 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

返回頂部