Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

How can I write SMS coming from GSM modem in the text file using the com port ?

Posted on 2004-09-17
3
Medium Priority
?
340 Views
Last Modified: 2013-12-26
Hi experts,
I'm a VB programer, I have some problem to write the data coming from GSM modem "Fastrack" in the text file using the com port.
This my code source
Private Sub Form_Load()
'Paramètres du 1er modem
MSComm1.RTSEnable = True
MSComm1.CommPort = 1
MSComm1.Settings = "9600,N,8,1"
MSComm1.InputLen = 0
MSComm1.PortOpen = True
MSComm1.Output = "AT+CNMI=0,2,0,0,0" & vbCr
End Sub
Private Sub MSComm1_OnComm()
   Select Case MSComm1.CommEvent
            Case comEvReceive  
            Open "C:\Receiv1_sms.txt" For Append As #1
            Print #1, MSComm1.Input
           Close #1
   End Select
  End Sub
With this I write the sms in the text file but when I read it I have the format problem....
+CMT: "+2236799488",,"04/09/16,09:40:47-00"
Hello

+CMT: "+2236722223",,"04/09/16
Hello

+CMT: "+2236715596",,"04/09/16
9-00"
F1

+CMT: "+2236761466",,"
,09:55:44-00"
Hello

+CMT: "+2236784793",,"04/09/16,10:00:58-00"
Hello

How can I do to receive all SMS  in the same format in the text file like this
+CMT: "+2236784793",,"04/09/16,10:00:58-00"
Hello
+CMT: "+2236799488",,"04/09/16,09:40:47-00"
Hello

Thanks for your help
0
Comment
Question by:toupe
  • 2
3 Comments
 
LVL 13

Expert Comment

by:imarshad
ID: 12091075
One other option is to use AT+CMGL command.....Depending upon the type of application you are developing AT+CMGL might be a better option..... Currently you have set your modem to Output the SMS as it arrives.......But what if at that time your Program is not running ? In that case you will not be able to read that SMS.......

AT+CMGL=4 (PDU Mode)
AT+CMGL="ALL" (Text Mode)

These commands will output all the SMS received serially.....and you manually have to delete each SMS you receive with AT+CMGD command......  

as far as your current code is concerned you might insert a delay after comEvReceive event is fired.......

            Case comEvReceive  
            Open "C:\Receiv1_sms.txt" For Append As #1
            sleep 500
            Print #1, MSComm1.Input
           Close #1

and declare sleep as
private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long) 'If declaring in form code


Hope this helps.....

Imran Arshad
0
 

Author Comment

by:toupe
ID: 12178046
Thanks for your help Imran, my program works properly now with Sleep Sub.
0
 
LVL 13

Accepted Solution

by:
imarshad earned 150 total points
ID: 12236674
If your problem is solved then you should close the question by accepting my suggestion......

Imran
0

Featured Post

Get expert help—faster!

Need expert help—fast? Use the Help Bell for personalized assistance getting answers to your important questions.

Question has a verified solution.

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

Background What I'm presenting in this article is the result of 2 conditions in my work area: We have a SQL Server production environment but no development or test environment; andWe have an MS Access front end using tables in SQL Server but we a…
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.
As developers, we are not limited to the functions provided by the VBA language. In addition, we can call the functions that are part of the Windows operating system. These functions are part of the Windows API (Application Programming Interface). U…
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…
Suggested Courses
Course of the Month12 days, 7 hours left to enroll

579 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