首 页       用户登录  |  用户注册
设为首页
加入收藏
联系我们
按字母检索 A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
按声母检索 A B C D E F G H J K L M N O P Q R S T W X Y Z 数字 符号
您的位置: 5VAR论文频道论文中心计算机论文计算机应用
   用VB实现班主任工作的电子化      ★★★ 【字体: 】  
用VB实现班主任工作的电子化
收集整理:佚名    来源:本站整理  时间:2009-01-10 11:55:21   点击数:[]    

[本篇论文由上帝论文网为您收集整理,上帝论文网http://paper.5var.com将为您整理更多优秀的免费论文,谢谢您的支持]

摘要:本文探讨了如何利用VB,读取数据库中的数据,通过Microsoft  MAPI  Controls 6.0控件,利用Outlook Express,从而实现成绩通知单以E-mail的形式自动寄发。

关键字:VB,E-mail, MAPI,自动寄发

一、问题提出
每期期未,寄发学生成绩通知单都是班主任的例行工作,然而,现在大多数人仍然还采用原始的平信寄发方式,并且由于平信很容易丢失而导致以前所做的工作(如抄录学生期末成绩、写出学生的学期鉴定,填写学生成绩通知单和写、写信封、寄发通知书等)前功尽弃,同时由于许多学生放假后并没有回家,如外去打工或因种种原因没有回家而无法收到信件。随着INTERNET技术的不断普及,电子邮件已经开始进入寻常百姓家,它以快速、方便、可以异地查阅而逐渐代替普通的信件,如果你的学生(或家长)都有E-mail,我们以E-mail来寄发学生的成绩通知单了,这样就可以减少上述弊端。但一个个填写每个学生的收件人地址和相关的数据(如各门功课的成绩、评语),既枯燥又烦锁,下面我们将探讨如何利用VB来读取学生成绩数据库中的数据,通过E-mail实现学生成绩通知单的自动寄发。
二、工作原理
学生成绩通知单各学校虽然有所不同,但大都大同小异,通常包括:学生各学科的成绩,操行分,班主任评语等内容(如上图)。如果这些内容都在数据库中,我们可以通过VB访问数据库来读取数据库中用户的E-mail地址、成绩及评语,再通过VB的Microsoft  MAPI  Controls 6.0控件中的MAPI Session和MAPI Messages两个控件进行电子邮件的管理,利用OutlookExpress。就能实现同时给班上所有学生用E-mail的自动发送通知书了。但由于各个学校成绩科目及多少不同,因此数据库中字段数就会不同,为使程序具有通用性,因此,在设计时我们使用了自动读取数据表中的字段个数和字段名,并自动在窗体上自动生成相对应的文本框和标签。
三、程序设计
1、      启动VB后,新建一个标准的EXE工程
2、      在“工具”菜单中选“部件”,在“控件”选项卡中选“Microsoft  MAPI  Controls 6.0”,在控件工具箱中将邮件控件MAPIMessages和MAPISession两个控件添加到窗体中。
2、添加两个命令按钮,将其CAPTION属性设计为“全部发送”和“退出”。
3、添加一个数据控件(Data1),并设置“Connect”、“DataBaseName”和“RecordSource”对应的属性。
上述三个控件最好放在窗体的下方。
4.编写源程序代码:将下面的代码添加到代码窗口中

Dim txtobject(20), lblObject(20)
Dim SendToText As String
Const M_Subject = "成绩通知单"

Private Sub Command2_Click()
Unload Me
End Sub
'定义一个用来回复(发送邮件)的函数
Public Function StarSend(T1, T2, T3)
        MAPIMessages1.MsgIndex = -1
        MAPIMessages1.RecipDisplayName = T1
        MAPIMessages1.MsgSubject = T2
        MAPIMessages1.MsgNoteText = T3
        MAPIMessages1.SessionID = MAPISession1.SessionID
        'MAPIMessages1.AttachmentPathName = "e:/My Documents/注意事项.htm"  ' 确定要发送的电子邮件的附件
        MAPIMessages1.Send
End Function

Private Sub Command1_Click()
Data1.Recordset.MoveFirst
MAPISession1.SignOn
Do While Data1.Recordset.EOF = False
  Sum = Sum + 1
  ' SendToText指的是发送邮件的内容(邮件正文)
  SendToText = txtobject(1).Text + "同学" + Chr(13) + Chr(10) + "你好!" + Chr(13) + Chr(10)
  SendToText = SendToText + "现将你的成绩通知你,希望你在假期注意复习功课!" + Chr(13) + Chr(10)
  '下面将自动获得各学科的名称和成绩
    For i = 3 To Data1.Recordset.RecordCount
        SendToText = SendToText + lblObject(i).Caption + ":" + txtobject(i).Text + "分" + Chr(13) + Chr(10)
    Next
  SendToText = SendToText + "  班主任: 刘友生 " + Chr(13) + Chr(10)
  SendToText = SendToText + "湖南省衡阳经济贸易学校" + Chr(13) + Chr(10)
  SendToText = SendToText + "发信日期:" + Data$ + "  发信时间:" + Time$
  GetTxtName   ’调用函数
  Call StarSend(txtobject(2).Text, M_Subject, SendToText)
  Data1.Recordset.MoveNext
  If Data1.Recordset.EOF = True Then
      MsgBox Str(Sum) + "个人员的成绩通知单已经发送完毕!", , " 发 送 邮 件"
      End
  End If
Loop
End Sub
Private Sub GetFieldNum()
Data1.Recordset.MoveFirst
'自动获得数据表中字段数并在窗体中自动生成相应文本框和标签
For i = 1 To Data1.Recordset.Fields.Count
    b$ = "Text_" + LTrim(Str(i))
    b1$ = "Label_" + Trim(Str(i)
    Set txtobject(i) = Form1.Controls.Add("VB.TextBox", b$)
    Set lblObject(i) = Form1.Controls.Add("VB.Label", b1$)
’下面是用来确定标签和文本框中窗体中的位置  
       txtobject(i).Visible = True
    lblObject(i).Visible = True
    txtobject(i).Width = 2000
    lblObject(i).Width = 1200
    txtobject(i).Height = 350
    lblObject(i).Height = 350
    If i Mod 2 = 0 Then
        txtobject(i).Left = 4200
        lblObject(i).Left

[1] [2]  下一页


Tags:


文章转载请注明来源于:5VAR论文频道 http://paper.5var.com。本站内容整理自互联网,如有问题或合作请Email至:support@5var.com
或联系QQ37750965
提供人:佚名
  • 上一篇文章:在PowerBuilder中利用自动化技术调用Excel处理与打印表格

  • 下一篇文章:刍议防火墙的合理使用
  • 返回上一页】【打 印】【关闭窗口
    中查找“用VB实现班主任工作的电子化”更多相关内容 5VAR论文频道
    中查找“用VB实现班主任工作的电子化”更多相关内容 5VAR论文频道
    最新热点 最新推荐 相关新闻
  • ››Delphi 5 数据库应用中ODBC数据源的...
  • ››用Visual Basic 6.0实现自动化测试...
  • ››用JAVA制作ICQ
  • ››在IIS 4.0上配置虚拟主机实现虚拟I...
  • ››利用VB开发CAI课件
  • ››基于GP算法的知识发现系统
  • ››基于Client/Server 的课件系统的设...
  • ››WWW对大量数据查询的一种实现
  • ››基于PHP的Web数据库访问
  • ››Developer/2000中的Forms参数及应用...
  • ››用VB实现班主任工作的电子化
  • ››用VB实现对库文件的分割备份
  •   文章-网友评论:(评论内容只代表网友观点,与本站立场无关!)
    关于本站 - 网站帮助 - 广告合作 - 下载声明 - 网站地图
    Copyright © 2006-2033 5Var.Com. All Rights Reserved .