通过窗体向EXCEL表单添加数据

        我们经常用Excel制作各种表格,如公司管理人员制作公司成员的名单表;推销员制作客户名单表等。单纯利用Excel的功能我们会发现有如下几个问题:
  1、容易出错。
  2、不能检查是否重复输入登记。
  3、经常重复输入相同的内容。

  而通过VBA在Excel中建立窗体,通过窗体向Excel输入数据,可以避免以上问题。本例是一个简单的登记程序,其功能是通过窗体来向工作表中添加数据。下面是应用系统的建立过程。

一、创建用户窗体

        1.打开EXCEL,打开Visual Basic 编辑器(工具-->宏-->Visual Basic 编辑器)

        2.选择菜单中“插入”、“添加用户窗体”命令。

            在窗体上拖两个Label(姓名,电话)  两个TextBox(ID:txtName,txtTel)  两个按钮(输入 取消)

       3.根据情况,自设窗体大小

二、对控件进行功能设置
  用鼠标选中窗体上的控件并双击该控件或者用鼠标右键单击控件并选择“查看代码”命令,进入窗体对象的编程环境。

       输入按钮:

Private   Sub CommandButton1_Click()
    
'下面是当在窗体上单击“输入”按钮运行的代码
    
    
Dim counter As Integer  '计数器
    Dim sign As Boolean    '是否登记标志
    
    counter 
= 0
    sign 
= True

    
'验证用户是否已登记过
    Range("A1").Select
    
Do Until Selection.Offset(counter, 0).Value = ""
        
If txtName.Text = Selection.Offset(counter, 0).Value Then '验证判断条件:姓名(根据需求,可调整)
            sign = False
            
MsgBox ("此用户已经登记")
        
End If
        counter 
= counter + 1
    
Loop
    
Do Until Selection.Offset(counter, 0).Value = ""
       counter 
= counter + 1
    
Loop
    
    
'登记信息(根据需求,可调整)
    If sign Then
        Selection.Offset(counter, 
0).Value = txtName.Text
        Selection.Offset(counter, 
1).Value = txtTel.Text
    
End If

End Sub
     取消按钮:
Private   Sub CommandButton2_Click()

    UserForm1.Hide
    
End Sub

 

三.在Excel中引用窗体

     1.在VB辑编器中添加宏(模块)

       Sub Macro1()
             UserForm1.Show
       End Sub

     2.切换到EXCEL,添加命令按钮(视图-->工具栏-->窗体-->弹出工具框)

       选择工具框中的按钮,在点击EXCEL表单任意处会自动弹出“指定宏”窗口,选择Macro1宏。

       修改按钮文本:右击按钮可以找到编辑文字属性

      设置完毕后,点击按钮就能打开数据录入窗体了。

  • 7
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
第1章 窗体与界面设计 1 1.1 菜单应用 2 实例001 在系统菜单中添加菜单项 2 实例002 带历史信息的菜单 3 实例003 菜单动态合并 4 实例004 像“开始”菜单一样漂亮的菜单 5 实例005 多彩的菜单 6 实例006 可以拉伸的菜单界面 8 1.2 工具栏设计 9 实例007 带背景的工具栏 9 实例008 浮动工具栏 10 1.3 状态栏设计 11 实例009 在状态栏中显示检查框 11 实例010 带进度条的状态栏 12 实例011 状态栏中加入图标 13 1.4 导航菜单界面 14 实例012 OutLook界面 14 实例013 带导航菜单的主界面 15 实例014 图形化的导航界面 16 1.5 特色程序界面 18 实例015 类QQ的程序界面 18 实例016 类似Windows XP的程序界面 20 实例017 以图形按钮显示的界面 21 实例018 以树型显示的程序界面 23 实例019 以XPManifest组件显示界面 24 实例020 动态按钮的窗体界面 25 1.6 特殊形状的窗体 26 实例021 非矩形窗体 26 实例022 建立字体形状窗体 28 1.7 多媒体光盘 29 实例023 自动启动的多媒体光盘程序 29 实例024 为触摸屏程序添加虚拟键盘 30 实例025 触摸屏系统 31 1.8 窗体效果 33 实例026 半透明渐显窗体 33 实例027 窗口颜色的渐变 34 实例028 带背景的窗体 35 实例029 为窗体增加边框 36 1.9 窗体动画 37 实例030 窗体中的滚动字幕 37 实例031 动画显示窗体 38 实例032 制作闪烁的窗体 39 实例033 直接在窗体上绘图 40 实例034 动画形式的程序界面 41 实例035 以时钟显示界面窗体 42 1.10 标题栏窗体 44 实例036 标题栏上的按钮 45 实例037 使窗体标题栏文字右对齐 47 实例038 没有标题栏但可以改变大小的窗口 48 1.11 设置窗体位置 49 实例039 不可移动的窗体 49 实例040 设置窗体在屏幕中的位置 50 实例041 始终在最上面的窗体 51 1.12 设置窗体大小 52 实例042 限制窗体大小 52 实例043 获取桌面大小 53 实例044 组件大小随窗体的改变而改变 53 实例045 在窗口间移动按钮 54 实例046 如何实现Office助手 55 1.13 窗体控制技术 56 实例047 在关闭窗口前加入确认对话框 56 实例048 程序在循环中响应界面操作 57 实例049 使用任意组件拖动窗体 58 实例050 动态创建窗体和释放窗体 59 实例051 修改提示字体及颜色 60 1.14 其他技术 61 实例052 窗口融合技术 61 实例053 给MDI窗体加背景 62 实例054 如何关闭MDI类型窗体中的子窗体 63 实例055 向提示框中添加图标 64 第2章 控件应用 67 2.1 TEdit控件应用典型实例 68 实例056 从右至左输入数据 68 实例057 为TEdit控件添加列表选择框 69 实例058 只允许输入数字的TEdit组件 70 2.2 TSpeedButton控件应用典型实例 71 实例059 在TSpeedButton按钮中显示图标 71 实例060 折行显示按钮标题 72 2.3 TMemo控件应用典型实例 73 实例061 设置TMemo组件的边界 73 实例062 TMemo组件的光标定位 74 实例063 得到TMemo中的可见行数 75 2.4 TListBox控件应用典型实例 76 实例064 在TListBox组件间交换数据 76 实例065 为TListBox添加水平滚动条 77 实例066 将数据数据添加到组合框中 78 实例067 借助绑定控件实现数据选择录入 79 2.5 TListView控件应用典型实例 80 实例068 TListView列表拒绝添加重复信息 80 实例069 将数据数据添加到TListView控件 82 实例070 用TListView控件制作导航界面 83 实例071 在TListView控件中对数据排序或统计 84 实例072 在TListView组件中绘制底纹 86 实例073 在列表视图中拖动视图项 87 2.6 TTreeView控件应用典型实例 88 实例074 将数据数据显示到树视图中 88 实例075 用TTreeView控件制作导航界面 90 实例076 TTreeView组件遍历磁盘目录 91 实例077 TTreeView组件在数据库中的应用 92 2.7 TStringGrid控件应用典型实例 94 实例078 程序运行时对
要实现这个功能,你需要进行以下步骤: 1. 在Winform窗体添加一个“打开文件”按钮,让用户可以选择要导入的Excel文件。 2. 使用C#的Excel Interop库或第三方库,读取Excel文件中的数据。如果数据量很大,可以考虑使用分页读取的方式,避免内存溢出。 3. 将读取到的数据存储在内存中,可以使用List、DataTable等数据结构。 4. 使用C#的MySQL Connector库连接到MySQL数据库,将数据写入数据库中。同样需要考虑性能问题,可以使用事务等方式提高写入效率。 下面是一个简单的示例代码,供参考: ```csharp using System; using System.Collections.Generic; using System.Data; using System.Windows.Forms; using MySql.Data.MySqlClient; using Excel = Microsoft.Office.Interop.Excel; namespace ExcelToMySQL { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void btnOpen_Click(object sender, EventArgs e) { // 打开Excel文件 OpenFileDialog openFileDialog = new OpenFileDialog(); openFileDialog.Filter = "Excel文件|*.xlsx;*.xls"; if (openFileDialog.ShowDialog() == DialogResult.OK) { // 读取Excel文件中的数据 Excel.Application excel = new Excel.Application(); Excel.Workbook workbook = excel.Workbooks.Open(openFileDialog.FileName); Excel.Worksheet worksheet = workbook.Sheets[1]; Excel.Range range = worksheet.UsedRange; List<string[]> dataList = new List<string[]>(); for (int i = 2; i <= range.Rows.Count; i++) { string[] data = new string[range.Columns.Count]; for (int j = 1; j <= range.Columns.Count; j++) { data[j - 1] = range.Cells[i, j].Value.ToString(); } dataList.Add(data); } workbook.Close(); excel.Quit(); // 将数据写入MySQL数据库 string connStr = "server=localhost;user=root;database=test;password=123456;"; MySqlConnection conn = new MySqlConnection(connStr); conn.Open(); MySqlTransaction transaction = conn.BeginTransaction(); try { foreach (string[] data in dataList) { string sql = "INSERT INTO table_name (column1, column2, column3) VALUES (@value1, @value2, @value3)"; MySqlCommand command = new MySqlCommand(sql, conn, transaction); command.Parameters.AddWithValue("@value1", data[0]); command.Parameters.AddWithValue("@value2", data[1]); command.Parameters.AddWithValue("@value3", data[2]); command.ExecuteNonQuery(); } transaction.Commit(); MessageBox.Show("导入成功!"); } catch (Exception ex) { transaction.Rollback(); MessageBox.Show("导入失败:" + ex.Message); } conn.Close(); } } } } ``` 在上面的示例代码中,需要将“table_name”和“column1/2/3”替换成实际的表名和列名。此外,还需要将“server”、“user”、“database”和“password”替换成实际的MySQL连接信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值