百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

VB.NET用文本文件做数据库 vbnet操作txt文本文档

yuyutoo 2024-10-12 01:33 4 浏览 0 评论

如果记录不多,用一个文本文件来作数据库,速度也可以,管理也方便。

下面我来做一个给大家看看,在窗体上拖一堆控件,从上到下,从左到右,控件分别是:LabelID, Label0, Picture1, Label6, Label1, Label2, Label3, Label4, Label5, NumericUpDown1, ButtonGO, ButtonFirst, Button1, Button2, ButtonEnd

如下图所示

  1. 首先 Imports System.IO 然后建立一个模块,用于一行行地读入文本文件并保存到数组,上一篇文章有说明。
  2. 有了数组后,就操作数组。文本数据库,其实就是操作数组的数据元素。
  3. 界面上最底下5个按钮,其实就是改变数据的ID号,然后把数组的不同显示出来。
  4. 专门创建一个模块,Display,用于把数据显示在界面上:根据改变的NowID很容易得到数据的数据元素,这个数据是由题目,答案1,答案2等用~符号连接组成的一行文本,我们用Split()函数将分解。

对了,上一篇文章已经说明,题库文本文件地址在:"D:\test\tiku.txt" ,在此目录里有一个BMP目录,已经有一个图片文件,9.png 图片如下:

全部代码如下:

Imports System.IO
Public Class Form1

    Dim SList() As String '先定义一个数组,用来保存题库
    Dim yyy() As String '查到每一条记录再分解成编码,汉字
    Dim nowID As UInteger '目前的记录指针位置

    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        NewSJK() ' 读入文本文件,再转为数组,操作文本数据库就是操作这个数组
        NumericUpDown1.Value = 1
        NumericUpDown1.Minimum = 1
        NumericUpDown1.Maximum = UBound(SList) + 1

        nowID = 0
        LabelID.Text = (nowID + 1).ToString
        display()

    End Sub

    Private Sub NewSJK()
        Dim FilePath As String = "D:\test\tiku.txt"
        If Dir(FilePath) = "" Then
            MsgBox("没有找到tiku.txt文件",, “提示”)
            Exit Sub
        End If

        Dim LineN As Integer = File.ReadAllLines(FilePath).Length ' 得到文本文件的总行数
        ReDim SList(LineN - 1) '定义数组大小,大小就根据文本文件的总行数来确定

        Dim I As Integer
        Dim Str1 As String '读出一行的文本

        I = -1 '初始值 

        FileOpen(1, FilePath, OpenMode.Input)

        Do While Not EOF(1)
            Str1 = LineInput(1)   ' 读一行
            I = I + 1
            SList(I) = Str1 '把读出的一行加入到数组里
        Loop

        FileClose(1)

    End Sub

    Private Sub ButtonFirst_Click(sender As Object, e As EventArgs) Handles ButtonFirst.Click
        '到第1条记录
        nowID = 0 '这个指针是指数组的序号,显示的序号必须要加1
        display()
    End Sub

    Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.Click
        '上一条记录
        If nowID = 0 Then
            MsgBox("已经是第1条记录了",, “提示”)
        Else
            nowID = nowID - 1
            display()
        End If
    End Sub

    Private Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.Click
        '下一条记录
        If nowID = UBound(SList) Then
            MsgBox("已经是最后记录了",, “提示”)
        Else
            nowID = nowID + 1
            display()
        End If
    End Sub

    Private Sub ButtonEnd_Click(sender As Object, e As EventArgs) Handles ButtonEnd.Click
        '到最后记录
        nowID = UBound(SList) '这个指针是指数组的序号,显示的序号必须要加1
        display()
    End Sub

    Private Sub ButtonGO_Click(sender As Object, e As EventArgs) Handles ButtonGO.Click
        '到指定的记录
        nowID = NumericUpDown1.Value - 1
        display()
    End Sub

    Private Sub display()
        '显示模块
        '将数组分解,分解成:ID,题目,答案1,答案2,答案3,答案4,正确答案,图片名,然后在界面上显示每一条记录
        yyy = Split(SList(nowID), "~") '用Split来分解,分解符是~

        LabelID.Text = (nowID + 1).ToString
        Label0.Text = yyy(0) '题目
        Label1.Text = yyy(1)
        Label2.Text = yyy(2)
        Label3.Text = yyy(3)
        Label4.Text = yyy(4)
        Label5.Text = yyy(5) '答案
        LabelBMP.Text = yyy(6) '图片名

        NumericUpDown1.Value = nowID + 1
    End Sub

    Private Sub LabelBMP_TextChanged(sender As Object, e As EventArgs) Handles LabelBMP.TextChanged
        If LabelBMP.Text <> "" Then
            PictureBox1.ImageLocation = "d:\test\bmp\" & LabelBMP.Text
        Else
            '图片为空
            PictureBox1.ImageLocation = ""
        End If
    End Sub
    
End Class

在visual studio 2022 测试成功,运行结果如下:

注意:文件文件需要UTF-8

说明,我用文件做数据库,几万条记录,用二分查询法,查询速度也比较快,有实用价值。

相关推荐

网站建设:从新手到高手

现代化网站应用领域非常广泛,从个人形象网站展示、企业商业网站运作、到政府公益等服务网站,各行各业都需要网站建设。大体上可以归结四类:宣传型网站设计、产品型网站制作、电子商务型网站建设、定制型功能网站开...

JetBrains 推出全新 AI 编程工具 Junie,助力高效开发

JetBrains宣布推出名为Junie的全新AI编程工具。这款工具不仅能执行简单的代码生成与检查任务,还能应对编写测试、验证结果等复杂项目,为开发者提供全方位支持。根据SWEBench...

AI也能写代码!代码生成、代码补全、注释生成、代码翻译轻松搞定

清华GLM技术团队打造的多语言代码生成模型CodeGeeX近期更新了新的开源版本「CodeGeeX2-6B」。CodeGeeX2是多语言代码生成模型CodeGeeX的第二代模型,不同于一代CodeG...

一键生成前后端代码,一个36k星的企业级低代码平台

「企业级低代码平台」前后端分离架构SpringBoot2.x,SpringCloud,AntDesign&Vue,Mybatis,Shiro,JWT。强大的代码生成器让前后端代码一键生成,无需写任...

Gitee 代码托管实战指南:5 步完成本地项目云端同步(附避坑要点)

核心流程拆解:远程仓库的搭建登录Gitee官网(注册账号比较简单,大家自行操作),点击“新建仓库”,建议勾选“初始化仓库”和“设置模板文件”(如.gitignore),避免上传临时文件。...

jeecg-boot 源码项目-强烈推荐使用

JEECGBOOT低代码开发平台...

JetBrains推出全新AI编程工具Junie,强调以开发者为中心

IT之家2月1日消息,JetBrains发文,宣布推出一款名为Junie的全新AI编程工具,官方声称这款AI工具既能执行简单的代码生成与检查等基础任务,也能应对“编写测试、验证结...

JetBrains旗下WebStorm和Rider现已加入“非商用免费”阵营

IT之家10月25日消息,软件开发商JetBrains今日宣布,旗下WebStorm(JavaScript开发工具)和Rider(.NET开发工具)现已加入“非商用免费”阵营。如果...

谈谈websocket跨域

了解websocketwebsocket是HTML5的新特性,在客户端和服务端提供了一个基于TCP连接的双向通道。...

websocket调试工具

...

利用webSocket实现消息的实时推送

1.什么是webSocketwebSocket实现实现推送消息WebSocket是HTML5开始提供的一种在单个TCP连接上进行全双工通讯的协议。以前的推送技术使用Ajax轮询,浏览器需...

Flutter UI自动化测试技术方案选型与探索

...

为 Go 开发的 WebSocket 库

#记录我的2024#...

「Java基础」Springboot+Websocket的实现后端数据实时推送

这篇文章主要就是实现这个功能,只演示一个基本的案例。使用的是websocket技术。...

【Spring Boot】WebSocket 的 6 种集成方式

介绍...

取消回复欢迎 发表评论: