這是我利用文件操作方法編寫的文件16進制察看軟件。本來是可以利用UltraEdit來干這件事的。我編寫的目的就是想看一下自己能不能編出來。于是我就用VB編了一下,先前我只是把源代碼直接放到網上,沒想到大家很支持我,給了我很大的鼓舞,在這里我十分感謝eastunfail的幫助,使我的代碼更加完善。
源代碼如下:
Dim col As ColumnHeader
Dim litem As ListItem
Dim sb As ListSubItem
Dim filename As String
Dim index As Long
Private Sub Command1_Click()
Dim b As Byte
'Dim ff() As Byte
Dim fl As Long
Dim sect As Long
Dim ss As Long
ListView1.ListItems.Clear
dlg.ShowOpen
filename = dlg.filename
fl = FileLen(filename)
sect = fl / 16
ss = fl Mod 16
Open filename For Binary As #1
If sect = 0 Then
Set litem = ListView1.ListItems.Add()
For index = 1 To ss
Get #1, index, b
Set sb = litem.ListSubItems.Add(index, , DecToHex(b))
Next index
End If
If sect <> 0 Then
For i = 1 To sect
Set litem = ListView1.ListItems.Add()
For index = 1 To 16
Get #1, 16 * (i - 1) + index, b
Set sb = litem.ListSubItems.Add(index, , DecToHex(b))
Next index
Next i
Set litem = ListView1.ListItems.Add()
For index = 1 To ss
Get #1, index, b
Set sb = litem.ListSubItems.Add(index, , DecToHex(b))
Next index
End If
Close #1
End Sub
Private Sub Command2_Click()
MsgBox "Welcome To Three Leaf WorkRoom!!", , "About"
End Sub
Private Sub Form_Load()
Dim i As Integer
ListView1.ColumnHeaders.Add , , "Address", ListView1.Width / 14
For i = 1 To 16
Set col = ListView1.ColumnHeaders.Add()
col.Text = "+" & DecToHex(i - 1)
col.Width = ListView1.Width / 25
Next
ListView1.ColumnHeaders.Add , , "ASCII", ListView1.Width / 4
End Sub
Private Function DecToHex(dd As Byte) As String
DecToHex=IIf(Dec>&HF,Hex(dd),"0" & Hex(dd)) '這行代碼是eastunfail提供的。
End Function
原文轉自:http://www.anti-gravitydesign.com