Solved

Open files in binary format

Posted on 2004-08-27
3
227 Views
Last Modified: 2010-05-02
Does anyone have the code to open any file in binary format and code to open a file which has been converted to binary back to its original state

e.g. opening a text file in binary so it comes out as 0's and 1's then change that back to whatever was in the text file...

Thanx for your help
0
Comment
Question by:mad_psyso
  • 2
3 Comments
 
LVL 8

Expert Comment

by:mladenovicz
ID: 11914474
I am not sure If I understood you properly, but here is the code to load file to byte array

Private Sub ReadBinary(FileName As String)
Dim FileName As String
Dim FN As Long
Dim arrData() As Byte
   
    FN = FreeFile
   
    Open FileName For Binary Access Read As #FN
   
    ReDim arrData(LOF(FN) - 1)

    Get #FN, , arrData()
   
    Close FN

End Sub
0
 

Author Comment

by:mad_psyso
ID: 11914609
Open a file in binary format and display it in a textbox then in another textbox convert it from binary back to its original format

If i has a textfile which contained "HELLO" textbox1 should display
01001000 01000101 01001100 01001100 01001111
which is the binary format

Then in the next textbox it should convert
01001000 01000101 01001100 01001100 01001111
back to its real state which would be back to "HELLO"
0
 
LVL 8

Accepted Solution

by:
mladenovicz earned 200 total points
ID: 11914728
Public Function BinaryToDecimal(Binary As String) As Long
    Dim n As Long
    Dim s As Integer
   
    For s = 1 To Len(Binary)
        n = n + (Mid(Binary, Len(Binary) - s + 1, 1) * (2 ^ (s - 1)))
    Next s
   
    BinaryToDecimal = n
End Function

Public Function DecimalToBinary(DecimalNum As Long) As String
    Dim tmp As String
    Dim n As Long
   
    n = DecimalNum
   
    tmp = Trim(Str(n Mod 2))
    n = n \ 2
   
    Do While n <> 0
        tmp = Trim(Str(n Mod 2)) & tmp
        n = n \ 2
    Loop
   
    DecimalToBinary = tmp
End Function

Public Function StringToBinary(s As String) As String
Dim i As Integer
Dim R As String
    For i = 1 To Len(s)
        R = R & DecimalToBinary(Asc(Mid(s, i, 1))) & " "
    Next
    StringToBinary = R
End Function

'-- input string should be separated by spaces
Public Function BinaryToString(B As String) As String
Dim i As Integer
Dim Arr() As String
Dim R As String
   
    Arr = Split(B, " ")
   
    For i = LBound(Arr) To UBound(Arr)
        R = R & Chr(BinaryToDecimal(Arr(i)))
    Next
    BinaryToString = R
End Function
0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

I’ve seen a number of people looking for examples of how to access web services from VB6.  I’ve been using a test harness I built in VB6 (using many resources I found online) that I use for small projects to work out how to communicate with web serv…
Since upgrading to Office 2013 or higher installing the Smart Indenter addin will fail. This article will explain how to install it so it will work regardless of the Office version installed.
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question