VB.Net - 正则表达式

正则表达式是可以与输入文本匹配的模式。 .Net框架提供了允许这种匹配的正则表达式引擎。 模式由一个或多个字符文字,运算符或构造组成。

定义正则表达式的构造

有各种类别的字符,运算符和构造,允许您定义正则表达式。 单击以下链接以查找这些结构。

  • 字符转义
  • 字符类
  • 分组构造
  • 量词
  • 反向引用结构
  • 交替结构
  • 替换
  • 杂项结构

正则表达式类

正则表达式类用于表示一个正则表达式。

正则表达式类有以下常用方法:

SN 方法和说明
1

Public Function IsMatch (input As String) As Boolean
公共函数IsMatch(输入作为字符串)作为布尔

表示在正则表达式构造函数中指定的正则表达式是否发现在指定的输入字符串匹配。

2

Public Function IsMatch (input As String, startat As Integer ) As Boolean

公共函数IsMatch(输入作为字符串,startat作为整数)作为布尔

指示在Regex构造函数中指定的正则表达式是否在指定的输入字符串中找到匹配项,从字符串中指定的起始位置开始。

3

Public Shared Function IsMatch (input As String, pattern As String ) As Boolean

公共共享函数IsMatch(输入作为字符串,图案作为字符串)作为布尔

指示指定的正则表达式是否在指定的输入字符串中找到匹配项。

4

Public Function Matches (input As String) As MatchCollection

公共函数匹配(输入作为字符串)作为MatchCollection

搜索指定的输入字符串以查找正则表达式的所有出现。

5

Public Function Replace (input As String, replacement As String) As String

公共函数替换(输入作为字符串,更换作为字符串)作为字符串

在指定的输入字符串中,使用指定的替换字符串替换与正则表达式模式匹配的所有字符串。

6

Public Function Split (input As String) As String()

公共函数(输入作为字符串)作为字符串()

将输入字符串插入到由正则表达式构造函数中指定一个正则表达式模式定义的位置的子字符串数组。

有关方法和属性的完整列表,请参阅Microsoft文档。

示例1

以下示例匹配以“S”开头的单词:

Imports System.Text.RegularExpressions
Module regexProgSub showMatch(ByVal text As String, ByVal expr As String)Console.WriteLine("The Expression: " + expr)Dim mc As MatchCollection = Regex.Matches(text, expr)Dim m As MatchFor Each m In mcConsole.WriteLine(m)Next mEnd SubSub Main()Dim str As String = "A Thousand Splendid Suns"Console.WriteLine("Matching words that start with 'S': ")showMatch(str, "SS*")Console.ReadKey()End Sub
End Module

当上述代码被编译和执行时,它产生了以下结果:

Matching words that start with 'S':
The Expression: SS*
Splendid
Suns

例2

以下示例匹配以“m”开头并以“e”结尾的单词:

Imports System.Text.RegularExpressions
Module regexProgSub showMatch(ByVal text As String, ByVal expr As String)Console.WriteLine("The Expression: " + expr)Dim mc As MatchCollection = Regex.Matches(text, expr)Dim m As MatchFor Each m In mcConsole.WriteLine(m)Next mEnd SubSub Main()Dim str As String = "make a maze and manage to measure it"Console.WriteLine("Matching words that start with 'm' and ends with 'e': ")showMatch(str, "mS*e")Console.ReadKey()End Sub
End Module

当上述代码被编译和执行时,它产生了以下结果:

Matching words start with 'm' and ends with 'e':
The Expression: mS*e
make
maze
manage
measure

例3

此示例替换了额外的空白空间:

Imports System.Text.RegularExpressions
Module regexProgSub Main()Dim input As String = "Hello    World   "Dim pattern As String = "s+"Dim replacement As String = " "Dim rgx As Regex = New Regex(pattern)Dim result As String = rgx.Replace(input, replacement)Console.WriteLine("Original String: {0}", input)Console.WriteLine("Replacement String: {0}", result)Console.ReadKey()End Sub
End Module

当上述代码被编译和执行时,它产生了以下结果:

Original String: Hello   World
Replacement String: Hello World   

VB.Net - 数据库访问

应用程序与数据库通信,首先,检索存储在那里的数据,并以用户友好的方式呈现它,其次,通过插入,修改和删除数据来更新数据库。

Microsoft ActiveX Data Objects.Net(ADO.Net)是一个模型,.Net框架的一部分,由.Net应用程序用于检索,访问和更新数据。

ADO.Net对象模型

ADO.Net对象模型只不过是通过各种组件的结构化流程。 对象模型可以被图形描述为:

通过数据提供者检索驻留在数据存储或数据库中的数据。 数据提供者的各种组件检索应用程序的数据并更新数据。

应用程序通过数据集或数据读取器访问数据。

  • Datasets 数据集:数据集将数据存储在断开连接的缓存中,应用程序从中检索数据。

  • Data readers 数据读取:数据读取器以只读和仅转发模式向应用程序提供数据。

数据提供程序

数据提供程序用于连接到数据库、 执行命令和检索数据,将其存储在一个数据集,阅读检索到的数据和更新数据库。

在 ADO.Net 数据提供程序包括以下四个对象︰

SN 对象和说明
1

Connection

This component is used to set up a connection with a data source.

该组件被用来建立与数据源的连接。

2

Command

A command is a SQL statement or a stored procedure used to retrieve, insert, delete or modify data in a data source.

命令是用于检索,插入,删除或修改数据源中的数据的SQL语句或存储过程。

3

DataReader

Data reader is used to retrieve data from a data source in a read-only and forward-only mode.

数据读取器用于以只读和仅转发模式从数据源检索数据。

4

DataAdapter

This is integral to the working of ADO.Net since data is transferred to and from a database through a data adapter. It retrieves data from a database into a dataset and updates the database. When changes are made to the dataset, the changes in the database are actually done by the data adapter.

这是ADO.Net的工作的组成部分,因为数据通过数据适配器传输到数据库和从数据库传输。 它将数据从数据库检索到数据集并更新数据库。 当对数据集进行更改时,数据库中的更改实际上由数据适配器完成。

ADO.Net中包含以下不同类型的数据提供程序

  • SQL Server的.Net Framework数据提供者 - 提供对Microsoft SQL Server的访问。

  • OLE DB的.Net Framework数据提供者 - 提供对使用OLE DB公开的数据源的访问。

  • ODBC的.Net Framework数据提供程序 - 提供对ODBC公开的数据源的访问。

  • Oracle的.Net Framework数据提供程序 - 提供对Oracle数据源的访问。

  • EntityClient提供程序 - 允许通过实体数据模型(EDM)应用程序访问数据。

数据集

DataSet是数据的内存表示。 它是从数据库检索的断开连接的高速缓存的记录集。 当与数据库建立连接时,数据适配器创建数据集并在其中存储数据。 在检索数据并将其存储在数据集中之后,将关闭与数据库的连接。 这被称为“断开连接的架构”。 数据集用作包含表,行和列的虚拟数据库。

下图显示了数据集对象模型:

DataSet类存在于System.Data命名空间中。 下表描述了DataSet的所有组件:

SN 组件及说明
1

DataTableCollection

It contains all the tables retrieved from the data source.

它包含了从数据源中检索的所有表。

2

DataRelationCollection

It contains relationships and the links between tables in a data set.

它包含数据集中的表之间的关系和链接。

3

ExtendedProperties

It contains additional information, like the SQL statement for retrieving data, time of retrieval, etc.

它包含的其他信息,例如用于检索数据的SQL语句,检索的时间等

4

DataTable

It represents a table in the DataTableCollection of a dataset. It consists of the DataRow and DataColumn objects. The DataTable objects are case-sensitive.

它表示数据集的DataTableCollection中的表。它由DataRow和DataColumn对象组成。 DataTable对象区分大小写。

5

DataRelation

It represents a relationship in the DataRelationshipCollection of the dataset. It is used to relate two DataTable objects to each other through the DataColumn objects.

它表示数据集的DataRelationshipCollection中的关系。它用于通过DataColumn对象将两个DataTable对象相互关联。

6

DataRowCollection

It contains all the rows in a DataTable.

它包含DataTable中的所有行。

7

DataView

It represents a fixed customized view of a DataTable for sorting, filtering, searching, editing and navigation.

它表示用于排序,过滤,搜索,编辑和导航的DataTable的固定自定义视图。

8

PrimaryKey

It represents the column that uniquely identifies a row in a DataTable.

它表示唯一标识DataTable中某一行的列。

9

DataRow

It represents a row in the DataTable. The DataRow object and its properties and methods are used to retrieve, evaluate, insert, delete, and update values in the DataTable. The NewRow method is used to create a new row and the Add method adds a row to the table.

它表示DataTable中的一行。 DataRow对象及其属性和方法用于检索,评估,插入,删除和更新DataTable中的值。 NewRow方法用于创建一个新行,Add方法向表中添加一行。

10

DataColumnCollection

It represents all the columns in a DataTable.

它表示DataTable中的所有列。

11

DataColumn

It consists of the number of columns that comprise a DataTable.

它由组成DataTable的列数组成。

连接到数据库

.Net框架提供两种类型的Connection类:

  • SqlConnection -设计用于连接到Microsoft SQL Server。

  • OleDbConnection -设计用于连接到各种数据库,如Microsoft Access和Oracle。

示例1

我们有一个表存储在名为testDB的数据库中的名为Customers的Microsoft SQL Server中。 有关在SQL Server中创建数据库和数据库表的信息,请参考“SQL Server”教程。

让我们连接到此数据库。 执行以下步骤:

  • 选择工具 - >连接到数据库

  • 在“添加连接”对话框中选择服务器名称和数据库名称。

  • 单击测试连接按钮以检查连接是否成功。

  • 在表单上添加一个DataGridView。

  • 单击选择数据源组合框。

  • 单击添加项目数据源链接。

  • 这将打开“数据源配置向导”。

  • 选择“数据库”作为数据源类型

  • 选择的DataSet作为数据库模型。

  • 选择已设置的连接。

  • 保存连接字符串。

  • 在我们的示例中选择数据库对象Customers表,然后单击完成按钮。

  • 选择“预览数据”链接以查看“结果”网格中的数据:

当使用Microsoft Visual Studio工具栏上的“开始”按钮运行应用程序时,将显示以下窗口:

示例2

在这个例子中,让我们使用代码访问DataGridView控件中的数据。 执行以下步骤:

  • 在窗体中添加一个DataGridView控件和一个按钮。

  • 将按钮控件的文本更改为“填充”。

  • 双击按钮控件,为按钮的Click事件添加所需的代码,如下所示:

Imports System.Data.SqlClient
Public Class Form1Private Sub Form1_Load(sender As Object, e As EventArgs) _Handles MyBase.Load'TODO: This line of code loads data into the 'TestDBDataSet.CUSTOMERS' table.   You can move, or remove it, as needed.Me.CUSTOMERSTableAdapter.Fill(Me.TestDBDataSet.CUSTOMERS)' Set the caption bar text of the form.   Me.Text = "tutorialspoint.com"End SubPrivate Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickDim connection As SqlConnection = New sqlconnection()connection.ConnectionString = "Data Source=KABIR-DESKTOP; _Initial Catalog=testDB;Integrated Security=True"connection.Open()Dim adp As SqlDataAdapter = New SqlDataAdapter _("select * from Customers", connection)Dim ds As DataSet = New DataSet()adp.Fill(ds)DataGridView1.DataSource = ds.Tables(0)End Sub
End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口:

单击“填充”按钮可显示数据网格视图控件上的表:

创建表,列和行

我们已经讨论过,像DataTable,DataColumn和DataRow这样的DataSet组件允许我们分别创建表,列和行。

下面的例子演示了这个概念:

示例3

到目前为止,我们已经使用我们的计算机中已经存在的表和数据库。 在本示例中,我们将创建一个表,向其中添加列,行和数据,并使用DataGridView对象显示表。

执行以下步骤:

  • 在窗体中添加一个DataGridView控件和一个按钮。

  • 将按钮控件的文本更改为“填充”。

  • 在代码编辑器中添加以下代码。

Public Class Form1Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load' Set the caption bar text of the form.   Me.Text = "tutorialspont.com"End SubPrivate Function CreateDataSet() As DataSet'creating a DataSet object for tablesDim dataset As DataSet = New DataSet()' creating the student tableDim Students As DataTable = CreateStudentTable()dataset.Tables.Add(Students)Return datasetEnd FunctionPrivate Function CreateStudentTable() As DataTableDim Students As DataTableStudents = New DataTable("Student")' adding columnsAddNewColumn(Students, "System.Int32", "StudentID")AddNewColumn(Students, "System.String", "StudentName")AddNewColumn(Students, "System.String", "StudentCity")' adding rowsAddNewRow(Students, 1, "Zara Ali", "Kolkata")AddNewRow(Students, 2, "Shreya Sharma", "Delhi")AddNewRow(Students, 3, "Rini Mukherjee", "Hyderabad")AddNewRow(Students, 4, "Sunil Dubey", "Bikaner")AddNewRow(Students, 5, "Rajat Mishra", "Patna")Return StudentsEnd FunctionPrivate Sub AddNewColumn(ByRef table As DataTable, _ ByVal columnType As String, ByVal columnName As String)Dim column As DataColumn = _ table.Columns.Add(columnName, Type.GetType(columnType))End Sub'adding data into the tablePrivate Sub AddNewRow(ByRef table As DataTable, ByRef id As Integer,_ByRef name As String, ByRef city As String)Dim newrow As DataRow = table.NewRow()newrow("StudentID") = idnewrow("StudentName") = namenewrow("StudentCity") = citytable.Rows.Add(newrow)End SubPrivate Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickDim ds As New DataSetds = CreateDataSet()DataGridView1.DataSource = ds.Tables("Student")End Sub
End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口:

单击“填充”按钮可显示数据网格视图控件上的表:


VB.Net - Excel工作表

VB.Net提供对Microsoft Excel 2010的COM对象模型和应用程序之间的互操作性的支持。

要在应用程序中使用此互操作性,您需要在Windows窗体应用程序中导入命名空间Microsoft.Office.Interop.Excel。

从VB.Net创建一个Excel应用程序

让我们从Microsoft Visual Studio中的以下步骤开始创建窗体表单应用程序:文件 - >新建项目 - > Windows窗体应用程序

最后,选择确定,Microsoft Visual Studio创建您的项目并显示以下Form1。

在窗体中插入Button控件Button1。

向项目中添加对Microsoft Excel对象库的引用。 进行以下操作:

  • 从项目菜单中选择添加引用。

  • 在COM选项卡上,找到Microsoft Excel对象库,然后单击选择。

  • 点击OK。

双击代码窗口并填充Button1的Click事件,如下所示。

'  Add the following code snippet on top of Form1.vb
Imports Excel = Microsoft.Office.Interop.Excel
Public Class Form1Private Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickDim appXL As Excel.ApplicationDim wbXl As Excel.WorkbookDim shXL As Excel.WorksheetDim raXL As Excel.Range' Start Excel and get Application object.appXL = CreateObject("Excel.Application")appXL.Visible = True' Add a new workbook.wbXl = appXL.Workbooks.AddshXL = wbXl.ActiveSheet' Add table headers going cell by cell.shXL.Cells(1, 1).Value = "First Name"shXL.Cells(1, 2).Value = "Last Name"shXL.Cells(1, 3).Value = "Full Name"shXL.Cells(1, 4).Value = "Specialization"' Format A1:D1 as bold, vertical alignment = center.With shXL.Range("A1", "D1").Font.Bold = True.VerticalAlignment = Excel.XlVAlign.xlVAlignCenterEnd With' Create an array to set multiple values at once.Dim students(5, 2) As Stringstudents(0, 0) = "Zara"students(0, 1) = "Ali"students(1, 0) = "Nuha"students(1, 1) = "Ali"students(2, 0) = "Arilia"students(2, 1) = "RamKumar"students(3, 0) = "Rita"students(3, 1) = "Jones"students(4, 0) = "Umme"students(4, 1) = "Ayman"' Fill A2:B6 with an array of values (First and Last Names).shXL.Range("A2", "B6").Value = students' Fill C2:C6 with a relative formula (=A2 & " " & B2).raXL = shXL.Range("C2", "C6")raXL.Formula = "=A2 & "" "" & B2"' Fill D2:D6 values.With shXL.Cells(2, 4).Value = "Biology".Cells(3, 4).Value = "Mathmematics".Cells(4, 4).Value = "Physics".Cells(5, 4).Value = "Mathmematics".Cells(6, 4).Value = "Arabic"End With' AutoFit columns A:D.raXL = shXL.Range("A1", "D1")raXL.EntireColumn.AutoFit()' Make sure Excel is visible and give the user control' of Excel's lifetime.appXL.Visible = TrueappXL.UserControl = True' Release object references.raXL = NothingshXL = NothingwbXl = NothingappXL.Quit()appXL = NothingExit Sub
Err_Handler:MsgBox(Err.Description, vbCritical, "Error: " & Err.Number)End Sub
End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口:

单击按钮将显示以下excel表。 将要求您保存工作簿。


VB.Net - 发送邮件

VB.Net允许从您的应用程序发送电子邮件。 System.Net.Mail命名空间包含用于向简单邮件传输协议(SMTP)服务器发送电子邮件以进行传递的类。

下表列出了一些常用的类:

SN 描述
1 Attachment 表示对电子邮件的附件。
2 AttachmentCollection 存储要作为电子邮件的一部分发送的附件。
3 MailAddress 表示电子邮件发件人或收件人的地址。
4 MailAddressCollection 存储与电子邮件相关联的电子邮件地址。
5 MailMessage 表示可以使用SmtpClient类发送的电子邮件。
6 SmtpClient 允许应用程序使用简单邮件传输协议(SMTP)发送电子邮件。
7 SmtpException 表示当SmtpClient无法完成发送或SendAsync操作时抛出的异常。

SmtpClient类

SmtpClient类允许应用程序使用简单邮件传输协议(SMTP)发送电子邮件。

以下是SmtpClient类的一些常用属性:

SN 属性 描述
1 ClientCertificates 指定应使用哪些证书建立安全套接字层(SSL)连接。
2 Credentials 获取或设置用于验证发件人的凭据。
3 EnableSsl 指定SmtpClient是否使用安全套接字层(SSL)加密连接。
4 Host 获取或设置用于SMTP事务的主机的名称或IP地址。
5 Port 获取或设置用于SMTP事务的端口。
6 Timeout 获取或设置一个值,该值指定同步发送调用超时的时间量。
7 UseDefaultCredentials 获取或设置一个布尔值,该值控制是否随请求一起发送DefaultCredentials。

以下是SmtpClient类的一些常用方法:

SN 方法和说明
1

Dispose

向SMTP服务器发送QUIT消息,正常结束TCP连接,并释放SmtpClient类的当前实例使用的所有资源。

2

Dispose(Boolean)

向SMTP服务器发送QUIT消息,正常结束TCP连接,释放由SmtpClient类的当前实例使用的所有资源,并且可选地处置托管资源。

3

OnSendCompleted

引发SendCompleted事件。

4

Send(MailMessage)

将指定的消息发送到SMTP服务器进行传递。

5

Send(String,String,String,String)

将指定的电子邮件发送到SMTP服务器进行传送。消息发件人,收件人,主题和邮件正文使用String对象指定。

6

SendAsync(MailMessage,Object)

将指定的电子邮件发送到SMTP服务器进行传送。此方法不会阻止调用线程,并允许调用者将一个对象传递给操作完成时调用的方法。

7 SendAsync(String,String,String,String,Object)
将电子邮件发送到SMTP服务器进行传送。消息发件人,收件人,主题和邮件正文使用String对象指定。此方法不会阻止调用线程,并允许调用者将一个对象传递给操作完成时调用的方法。
8

SendAsyncCancel

取消异步操作以发送电子邮件。

9

SendMailAsync(MAILMESSAGE)

发送指定消息,以交付作为异步操作的SMTP服务器。

10 SendMailAsync(MailMessage)
将指定的消息发送到SMTP服务器以作为异步操作进行传递。
11 ToString
返回表示当前对象的字符串。

以下示例演示如何使用SmtpClient类发送邮件。 在这方面应注意以下几点:

  • 您必须指定用于发送电子邮件的SMTP主机服务器。 不同主机服务器的主机和端口属性将不同。 我们将使用gmail服务器。

  • 如果SMTP服务器需要,您需要授予认证凭据。

  • 您还应该分别使用MailMessage.From和MailMessage.To属性提供发件人的电子邮件地址和收件人的电子邮件地址。

  • 您还应该使用MailMessage.Body属性指定消息内容。

示例

在这个例子中,让我们创建一个发送电子邮件的简单应用程序。 执行以下步骤:

  • 在表单中添加三个标签,三个文本框和一个按钮控件。

  • 将标签的文本属性分别更改为 - “From”,“To:”和“Message:”。

  • 将文本的名称属性分别更改为txtFrom,txtTo和txtMessage。

  • 将按钮控件的文本属性更改为“发送”

  • 在代码编辑器中添加以下代码。

Imports System.Net.Mail
Public Class Form1Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load' Set the caption bar text of the form.   Me.Text = "tutorialspoint.com"End SubPrivate Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickTryDim Smtp_Server As New SmtpClientDim e_mail As New MailMessage()Smtp_Server.UseDefaultCredentials = FalseSmtp_Server.Credentials = New Net.NetworkCredential("username@gmail.com", "password")Smtp_Server.Port = 587Smtp_Server.EnableSsl = TrueSmtp_Server.Host = "smtp.gmail.com"e_mail = New MailMessage()e_mail.From = New MailAddress(txtFrom.Text)e_mail.To.Add(txtTo.Text)e_mail.Subject = "Email Sending"e_mail.IsBodyHtml = Falsee_mail.Body = txtMessage.TextSmtp_Server.Send(e_mail)MsgBox("Mail Sent")Catch error_t As ExceptionMsgBox(error_t.ToString)End TryEnd Sub

您必须提供您的gmail地址和真实密码以获取凭据。

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,将显示以下窗口,您将使用该窗口发送电子邮件,自行尝试。


VB.Net - XML处理

可扩展标记语言(XML)是一种非常类似于HTML或SGML的标记语言。 这是万维网联盟推荐的,可作为开放标准。

.Net框架中的System.Xml命名空间包含用于处理XML文档的类。 以下是System.Xml命名空间中常用的一些类。

SN 描述
1 XmlAttribute 表示属性。属性的有效值和默认值在文档类型定义(DTD)或模式中定义。
2 XmlCDataSection 表示一个CDATA部分。
3 XmlCharacterData 提供由几个类使用的文本处理方法。
4 XMLCOMMENT 表示一个XML注释的内容。
5 XmlConvert 对XML名称进行编码和解码,并提供在公共语言运行时类型和XML模式定义语言(XSD)类型之间进行转换的方法。转换数据类型时,返回的值与语言环境无关。
6 XmlDeclaration 表示XML声明节点<?xml version ='1.0'...?>。
7 XmlDictionary 实现一本字典用来优化 Windows 通信基础(WCF) 的 XML 读取器/编写器实现。
8 XmlDictionaryReader Windows Communication Foundation(WCF)从XmlReader派生来进行序列化和反序列化的抽象类。
9 XmlDictionaryWriter 表示Windows Communication Foundation(WCF)从XmlWriter派生来进行序列化和反序列化的抽象类。
10 XmlDocument 表示XML文档。
11 XmlDocumentFragment 表示对树插入操作有用的轻量级对象。
12 XmlDocumentType 表示文档类型声明。
13 XmlElement 表示一个元素。
14 XmlEntity 表示一个实体声明,如<!ENTITY ...>。
15 XmlEntityReference 表示一个实体引用节点。
16 XmlException 返回有关最后一个异常的详细信息。
17 XmlImplementation 定义一组XmlDocument对象的上下文。
18 XmlLinkedNode 获取此节点之前或之后的节点。
19 XmlNode 表示XML文档中的单个节点。
20 XmlNodeList 表示节点的有序集合。
21 XmlNodeReader 表示提供对XmlNode中的XML数据的快速,非缓存转发访问的阅读器。
22 XmlNotation 表示一个注释声明,如<!NOTATION ...>。
23 XmlParserContext 提供XmlReader解析XML片段所需的所有上下文信息。
24 XmlProcessingInstruction 表示处理指令,XML定义为在文档的文本中保留处理器特定的信息。
25 XmlQualifiedName 表示一个XML限定名称。
26 XmlReader 表示一个阅读器,提供了快速,非缓存,只进到XML数据访问。
27 XmlReaderSettings 指定一组要在Create方法创建的XmlReader对象上支持的要素。
28 XmlResolver 解析由统一资源标识符(URI)命名的外部XML资源。
29 XmlSecureResolver 有助于通过封装XmlResolver对象并限制底层XmlResolver有权访问的资源来保护XmlResolver的另一个实现。
30 XmlSignificantWhitespace 表示混合内容节点中的标记之间或xml:space ='preserve'范围内的空白空间中的空格。这也称为有效的空白空间。
31 XmlText 表示元素或属性的文本内容。
32 XmlTextReader 表示提供对XML数据的快速,非缓存,仅转发访问的阅读器。
33 XmlTextWriter 代表作家提供了一个快速,非缓存,只进生成包含符合W3C可扩展标记语言(XML)1.0和XML中建议的命名空间XML数据流或文件的方式。
34 XmlUrlResolver 解析由统一资源标识符(URI)命名的外部XML资源。
35 XmlWhitespace 代表元素内容中的空白。
36 XmlWriter 表示提供快速,非缓存,仅转发方式生成包含XML数据的流或文件的写入程序。
37 XmlWriterSettings 指定一组要在XmlWriter.Create方法创建的XmlWriter对象上支持的要素。

XML解析器的API

XML数据的两个最基本和广泛使用的API是SAX和DOM接口。

XML的简单API(SAX):在这里,您注册感兴趣的事件的回调,然后让解析器继续处理文档。这在文档很大或者有内存限制时很有用,它在从磁盘读取文件时解析文件,整个文件从不存储在内存中。

文档对象模型(DOM)API:这是万维网联盟推荐,其中整个文件被读入存储器并以分层(基于树)的形式存储以表示XML文档的所有特征。

SAX显然不能像使用大文件时DOM那样快速地处理信息。另一方面,使用DOM可以真正地杀死你的资源,特别是如果用于很多小文件。

SAX是只读的,而DOM允许更改XML文件。由于这两个不同的API字面上互补,没有理由你不能使用它们两个大项目。

对于所有的XML代码示例,让我们使用一个简单的XML文件movies.xml作为输入:

<?xml version="1.0"?><collection shelf="New Arrivals">
<movie title="Enemy Behind"><type>War, Thriller</type><format>DVD</format><year>2003</year><rating>PG</rating><stars>10</stars><description>Talk about a US-Japan war</description>
</movie>
<movie title="Transformers"><type>Anime, Science Fiction</type><format>DVD</format><year>1989</year><rating>R</rating><stars>8</stars><description>A schientific fiction</description>
</movie><movie title="Trigun"><type>Anime, Action</type><format>DVD</format><episodes>4</episodes><rating>PG</rating><stars>10</stars><description>Vash the Stampede!</description>
</movie>
<movie title="Ishtar"><type>Comedy</type><format>VHS</format><rating>PG</rating><stars>2</stars><description>Viewable boredom</description>
</movie>
</collection>

解析XML使用SAX API

在SAX模型中,使用XmlReader和XmlWriter类来处理XML数据。

XmlReader类用于以快速,仅向前和非缓存方式读取XML数据。 它读取XML文档或流。

示例1

此示例演示从文件movies.xml中读取XML数据。

执行以下步骤:

  • 将movies.xml文件添加到应用程序的bin \ Debug文件夹中。

  • 在Form1.vb文件中导入System.Xml命名空间。

  • 在表单中添加标签,并将其文字更改为“Movies Galore”。

  • 添加三个列表框和三个按钮,以显示来自xml文件的电影的标题,类型和描述。

  • 使用代码编辑器窗口添加以下代码。

Imports System.Xml
Public Class Form1Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load' Set the caption bar text of the form.   Me.Text = "tutorialspoint.com"End SubPrivate Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickListBox1().Items.Clear()Dim xr As XmlReader = XmlReader.Create("movies.xml")Do While xr.Read()If xr.NodeType = XmlNodeType.Element AndAlso xr.Name = "movie" ThenListBox1.Items.Add(xr.GetAttribute(0))End IfLoopEnd SubPrivate Sub Button2_Click(sender As Object, e As EventArgs) Handles Button2.ClickListBox2().Items.Clear()Dim xr As XmlReader = XmlReader.Create("movies.xml")Do While xr.Read()If xr.NodeType = XmlNodeType.Element AndAlso xr.Name = "type" ThenListBox2.Items.Add(xr.ReadElementString)Elsexr.Read()End IfLoopEnd SubPrivate Sub Button3_Click(sender As Object, e As EventArgs) Handles Button3.ClickListBox3().Items.Clear()Dim xr As XmlReader = XmlReader.Create("movies.xml")Do While xr.Read()If xr.NodeType = XmlNodeType.Element AndAlso xr.Name = "description" ThenListBox3.Items.Add(xr.ReadElementString)Elsexr.Read()End IfLoopEnd Sub
End Class

使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码。 单击按钮将显示文件中电影的标题,类型和描述。

XmlWriter类用于将XML数据写入流,文件或TextWriter对象。 它也以只向前,非缓存的方式工作。

示例2

让我们通过在运行时添加一些数据来创建一个XML文件。 执行以下步骤:

  • 在窗体中添加WebBrowser控件和按钮控件。

  • 将按钮的Text属性更改为显示作者文件。

  • 在代码编辑器中添加以下代码。

Imports System.Xml
Public Class Form1Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load' Set the caption bar text of the form.   Me.Text = "tutorialspoint.com"End SubPrivate Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickDim xws As XmlWriterSettings = New XmlWriterSettings()xws.Indent = Truexws.NewLineOnAttributes = TrueDim xw As XmlWriter = XmlWriter.Create("authors.xml", xws)xw.WriteStartDocument()xw.WriteStartElement("Authors")xw.WriteStartElement("author")xw.WriteAttributeString("code", "1")xw.WriteElementString("fname", "Zara")xw.WriteElementString("lname", "Ali")xw.WriteEndElement()xw.WriteStartElement("author")xw.WriteAttributeString("code", "2")xw.WriteElementString("fname", "Priya")xw.WriteElementString("lname", "Sharma")xw.WriteEndElement()xw.WriteStartElement("author")xw.WriteAttributeString("code", "3")xw.WriteElementString("fname", "Anshuman")xw.WriteElementString("lname", "Mohan")xw.WriteEndElement()xw.WriteStartElement("author")xw.WriteAttributeString("code", "4")xw.WriteElementString("fname", "Bibhuti")xw.WriteElementString("lname", "Banerjee")xw.WriteEndElement()xw.WriteStartElement("author")xw.WriteAttributeString("code", "5")xw.WriteElementString("fname", "Riyan")xw.WriteElementString("lname", "Sengupta")xw.WriteEndElement()xw.WriteEndElement()xw.WriteEndDocument()xw.Flush()xw.Close()WebBrowser1.Url = New Uri(AppDomain.CurrentDomain.BaseDirectory + "authors.xml")End Sub
End Class

使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码。 单击显示作者文件将在Web浏览器上显示新创建的authors.xml文件。

使用DOM API解析XML

根据文档对象模型(DOM),XML文档由节点和节点的属性组成。 XmlDocument类用于实现.Net框架的XML DOM解析器。 它还允许您通过插入,删除或更新文档中的数据来修改现有的XML文档。

以下是XmlDocument类的一些常用方法:

SN 方法名称和说明
1

AppendChild

将指定的节点添加到此节点的子节点列表的末尾。

2

CreateAttribute(String)

使用指定的名称创建XmlAttribute。

3

CreateComment

创建包含指定数据的XmlComment。

4

CreateDefaultAttribute

创建具有指定前缀,本地名称和命名空间URI的默认属性。

5

CreateElement(String)

创建具有指定名称的元素。

6

CreateNode(String, String, String)

创建具有指定节点类型,Name和NamespaceURI的XmlNode。

7

CreateNode(XmlNodeType, String, String)

创建具有指定的XmlNodeType,Name和NamespaceURI的XmlNode。

8

CreateNode(XmlNodeType, String, String, String)

创建具有指定的XmlNodeType,Prefix,Name和NamespaceURI的XmlNode。

9

CreateProcessingInstruction

创建具有指定名称和数据的XmlProcessingInstruction。

10

CreateSignificantWhitespace

创建一个XmlSignificantWhitespace节点。

11

createTextNode

创建具有指定文本的XMLTEXT。

12

CreateWhitespace

创建一个XmlWhitespace节点。

13

CreateXmlDeclaration

创建一个具有指定值的XmlDeclaration节点。

14

GetElementById

获取具有指定ID的XmlElement。

15

GetElementsByTagName(String)

返回一个包含与指定名称匹配的所有后代元素的列表的XmlNodeList。

16

GetElementsByTagName(String, String)

返回一个包含与指定名称匹配的所有后代元素的列表的XmlNodeList。

17

InsertAfter

在指定的引用节点之后立即插入指定的节点。

18

InsertBefore

在指定的引用节点之前插入指定的节点。

19

Load(Stream)

从指定的流装载XML文档。

20

Load(String)

从指定的TextReader加载XML文档。

21

Load(TextReader)

从指定的TextReader加载XML文档。

22

Load(XmlReader)

从指定的XmlReader加载XML文档。

23

LoadXml

从指定的字符串加载XML文档。

24

PrependChild

将指定的节点添加到此节点的子节点列表的开头。

25

ReadNode

基于XmlReader中的信息创建XmlNode对象。读取器必须位于节点或属性上。

26

RemoveAll

删除当前节点的所有子节点和/或属性。

27

RemoveChild

删除指定的子节点。

28

ReplaceChild

将子节点oldChild替换为newChild节点。

29

Save(Stream)

保存XML文档到指定的流。

30

Save(String)

将XML文档保存到指定的文件。

31

Save(TextWriter)

将XML文档保存到指定的TextWriter。

32

Save(XmlWriter)

将XML文档保存到指定的XmlWriter。

示例3

在本示例中,让我们在xml文档authors.xml中插入一些新节点,然后在列表框中显示所有作者的名字。

执行以下步骤:

  • 将authors.xml文件添加到应用程序的bin / Debug文件夹中(如果您已经尝试了最后一个示例,应该在那里)

  • 导入System.Xml命名空间

  • 在表单中添加列表框和按钮控件,并将按钮控件的text属性设置为“显示作者”。

  • 使用代码编辑器添加以下代码。

Imports System.Xml
Public Class Form1Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load' Set the caption bar text of the form.   Me.Text = "tutorialspoint.com"End SubPrivate Sub Button1_Click(sender As Object, e As EventArgs) Handles Button1.ClickListBox1.Items.Clear()Dim xd As XmlDocument = New XmlDocument()xd.Load("authors.xml")Dim newAuthor As XmlElement = xd.CreateElement("author")newAuthor.SetAttribute("code", "6")Dim fn As XmlElement = xd.CreateElement("fname")fn.InnerText = "Bikram"newAuthor.AppendChild(fn)Dim ln As XmlElement = xd.CreateElement("lname")ln.InnerText = "Seth"newAuthor.AppendChild(ln)xd.DocumentElement.AppendChild(newAuthor)Dim tr As XmlTextWriter = New XmlTextWriter("movies.xml", Nothing)tr.Formatting = Formatting.Indentedxd.WriteContentTo(tr)tr.Close()Dim nl As XmlNodeList = xd.GetElementsByTagName("fname")For Each node As XmlNode In nlListBox1.Items.Add(node.InnerText)Next nodeEnd Sub
End Class

使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码。 单击“显示作者”按钮将显示所有作者的名字,包括我们在运行时添加的作者。


VB.Net - Web编程

动态Web应用程序包括以下两种类型的程序之一或两者:

  • 服务器端脚本 -这些是在Web服务器上执行的程序,使用服务器端脚本语言(如ASP(Active Server Pages)或JSP(Java Server Pages))编写。

  • 客户端脚本 -这些是在浏览器上执行的程序,使用脚本语言(如JavaScript,VBScript等)编写。

ASP.Net是由Microsoft引入的ASP的.Net版本,用于通过使用服务器端脚本创建动态网页。 ASP.Net应用程序是使用.Net框架中存在的可扩展和可重用组件或对象编写的编译代码。这些代码可以使用.Net框架中的类的整个层次结构。

ASP.Net应用程序代码可以用以下任何一种语言编写:

  • Visual Basic .NET

  • C#

  • Jscript脚本

  • J#

在本章中,我们将简要介绍使用VB.Net编写ASP.Net应用程序。有关详细讨论,请参阅ASP.Net教程。

ASP.Net内置对象

ASP.Net有一些在Web服务器上运行的内置对象。 这些对象具有在应用程序开发中使用的方法,属性和集合。

下表列出了具有简要说明的ASP.Net内置对象:

目的 描述

Application 

应用

描述存储与整个Web应用程序相关的信息的对象的方法,属性和集合,包括应用程序生命周期中存在的变量和对象。
您使用此对象来存储和检索要在应用程序的所有用户之间共享的信息。例如,您可以使用Application对象来创建电子商务页面。

Request

请求

描述存储与HTTP请求相关的信息的对象的方法,属性和集合。这包括表单,Cookie,服务器变量和证书数据。
您使用此对象来访问在从浏览器到服务器的请求中发送的信息。例如,您可以使用Request对象来访问用户在HTML表单中输入的信息。
Response
响应
描述存储与服务器响应相关的信息的对象的方法,属性和集合。这包括显示内容,操作标头,设置区域设置和重定向请求。
您使用此对象向浏览器发送信息。例如,您使用Response对象将输出从脚本发送到浏览器。
Server
服务器
描述提供各种服务器任务的方法的对象的方法和属性。使用这些方法,您可以执行代码,获取错误条件,编码文本字符串,创建对象供网页使用,并映射物理路径。
您使用此对象访问服务器上的各种实用程序功能。例如,您可以使用Server对象为脚本设置超时。
Session
会话
描述存储与用户会话相关的信息的对象的方法,属性和集合,包括会话生存期内存在的变量和对象。
您使用此对象来存储和检索有关特定用户会话的信息。例如,您可以使用Session对象来保存有关用户及其首选项的信息,并跟踪待处理操作。

ASP.Net编程模型

ASP.Net提供两种类型的编程模型:

  • Web Forms-这使您能够创建将应用于用户界面的各种组件的用户界面和应用程序逻辑。

  • WCF Services-这使您可以远程访问一些服务器端功能。

对于本章,您需要使用免费的Visual Studio Web Developer。 IDE与您已经用于创建Windows应用程序的IDE几乎相同。

Web表单

Web表单包括:

  • 用户界面

  • 应用程序逻辑

用户界面包括静态HTML或XML元素和ASP.Net服务器控件。 创建Web应用程序时,HTML或XML元素和服务器控件存储在具有.aspx扩展名的文件中。 此文件也称为页面文件。

应用程序逻辑包括应用于页面中用户界面元素的代码。 你可以用任何.Net语言,如VB.Net或C#编写代码。

下图显示了“设计”视图中的Web窗体:

示例

让我们创建一个带有Web表单的新网站,该表单将显示用户点击按钮时的当前日期和时间。 执行以下步骤:

  • 选择文件 - >新建 - > Web站点。将出现“新建网站”对话框。

  • 选择ASP.Net空网站模板。 键入网站的名称,然后选择保存文件的位置。

  • 您需要向站点添加默认页面。 右键单击解决方案资源管理器中的网站名称,然后从上下文菜单中选择添加新项目选项。 将显示“添加新项”对话框:

  • 选择Web窗体选项并提供默认页面的名称。 我们把它保存为Default.aspx。 单击添加按钮。

  • 默认页面显示在源视图中

  • 通过向“值”添加值来设置“默认”网页的标题

  • 要在网页上添加控件,请转到设计视图。 在表单上添加三个标签,一个文本框和一个按钮。

  • 双击该按钮,并将以下代码添加到该按钮的Click事件:

Protected Sub Button1_Click(sender As Object, e As EventArgs) _
Handles Button1.ClickLabel2.Visible = TrueLabel2.Text = "Welcome to Tutorials Point: " + TextBox1.TextLabel3.Text = "You visited us at: " + DateTime.Now.ToString()
End Sub

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,浏览器中将打开以下页面:

输入您的姓名,然后点击提交按钮:

网页服务

Web服务是一个Web应用程序,基本上是一个由其他应用程序可以使用的方法组成的类。它也遵循代码隐藏架构,如ASP.Net网页,虽然它没有用户界面。

.Net Framework的早期版本使用了ASP.Net Web Service的这个概念,它具有.asmx文件扩展名。然而,从.Net Framework 4.0开始,Windows通信基础(WCF)技术已经发展成为Web Services,.Net Remoting和一些其他相关技术的新继任者。它把所有这些技术结合在一起。在下一节中,我们将简要介绍Windows Communication Foundation(WCF)。

如果您使用先前版本的.Net Framework,您仍然可以创建传统的Web服务。有关详细说明,请参阅ASP.Net - Web服务详细说明。

Windows通信基础

Windows Communication Foundation或WCF提供了一个用于创建分布式面向服务的应用程序的API,称为WCF服务。

像Web服务一样,WCF服务也支持应用程序之间的通信。但是,与Web服务不同,此处的通信不仅限于HTTP。 WCF可以配置为通过HTTP,TCP,IPC和消息队列使用。支持WCF的另一个强点是,它提供对双工通信的支持,而对于Web服务,我们只能实现单工通信。

从初学者的角度来看,编写WCF服务与编写Web服务并不完全不同。为了保持简单,我们将看到如何:

  • 创建一个WCF服务

  • 创建一个服务合同并定义操作

  • 执行合同

  • 测试服务

  • 使用该服务

示例

要理解这个概念,让我们创建一个简单的服务,提供股价信息。客户可以根据股票代号查询股票的名称和价格。为了保持这个例子简单,这些值被硬编码在二维数组中。此服务将有两种方法:

  • GetPrice方法 - 它将返回股票的价格,基于提供的符号。

  • GetName方法 - 它将返回股票的名称,基于提供的符号。

创建WCF服务

执行以下步骤:

  • 打开VS Express for Web 2012

  • 选择新的网站,打开新建网站对话框。

  • 选择模板列表中的WCF服务模板:

  • 从Web位置下拉列表中选择文件系统。

  • 提供WCF服务的名称和位置,然后单击“确定”。

创建一个新的WCF服务。

创建服务合同并定义操作

服务契约定义服务执行的操作。 在WCF服务应用程序中,您会发现在解决方案资源管理器中的App_Code文件夹中自动创建两个文件

  • IService.vb - 这将有服务合同; 在简单的话,它将有服务的接口,与服务将提供的方法的定义,您将在您的服务中实现。

  • Service.vb - 这将实现服务合同。

用给定的代码替换IService.vb文件的代码:

Public Interface IService<OperationContract()>Function GetPrice(ByVal symbol As String) As Double<OperationContract()>Function GetName(ByVal symbol As String) As String
End Interface

实施合同

在Service.vb文件中,您将找到一个名为Service的类,它将实现在IService接口中定义的服务契约。

使用以下代码替换IService.vb的代码:

' NOTE: You can use the "Rename" command on the context menu to change the class name "Service" in code, svc and config file together.
Public Class ServiceImplements IServicePublic Sub New()End SubDim stocks As String(,) ={{"RELIND", "Reliance Industries", "1060.15"},{"ICICI", "ICICI Bank", "911.55"},{"JSW", "JSW Steel", "1201.25"},{"WIPRO", "Wipro Limited", "1194.65"},{"SATYAM", "Satyam Computers", "91.10"}}Public Function GetPrice(ByVal symbol As String) As Double _Implements IService.GetPriceDim i As Integer'it takes the symbol as parameter and returns priceFor i = 0 To i = stocks.GetLength(0) - 1If (String.Compare(symbol, stocks(i, 0)) = 0) ThenReturn Convert.ToDouble(stocks(i, 2))End IfNext iReturn 0End FunctionPublic Function GetName(ByVal symbol As String) As String _Implements IService.GetName' It takes the symbol as parameter and ' returns name of the stockDim i As IntegerFor i = 0 To i = stocks.GetLength(0) - 1If (String.Compare(symbol, stocks(i, 0)) = 0) ThenReturn stocks(i, 1)End IfNext iReturn "Stock Not Found"End Function
End Class

测试服务

要运行如此创建的WCF服务,请从菜单栏中选择Debug-> Start Debugging选项。 输出将是:

要测试服务操作,请从左窗格的树中双击操作的名称。 新的选项卡将显示在右窗格中。

在右窗格的“请求”区域中输入参数值,然后单击“调用”按钮。

下图显示了测试GetPrice操作的结果:

下图显示了测试GetName操作的结果:

使用服务

让我们在同一个解决方案中添加一个默认页面,一个ASP.NET Web窗体,我们将使用我们刚刚创建的WCF服务。

执行以下步骤:

  • 右键单击解决方案资源管理器中的解决方案名称,并向解决方案添加新的Web表单。 它将被命名为Default.aspx。

  • 在表单上添加两个标签,一个文本框和一个按钮。

  • 我们需要添加一个服务引用到我们刚刚创建的WCF服务。 右键单击解决方案资源管理器中的网站,然后选择添加服务引用选项。 这将打开“添加服务引用”对话框。

  • 在地址文本框中输入服务的URL(位置),然后单击执行按钮。 它使用默认名称ServiceReference1创建服务引用。 单击确定按钮。

    添加引用为您的项目做了两个作业:

    • 在web.config文件中为服务创建地址和绑定。
    • 创建代理类以访问服务。

双击表单中的“获取价格”按钮,在其Click事件上输入以下代码段:

Partial Class _DefaultInherits System.Web.UI.PageProtected Sub Button1_Click(sender As Object, e As EventArgs) _Handles Button1.ClickDim ser As ServiceReference1.ServiceClient = _ New ServiceReference1.ServiceClientLabel2.Text = ser.GetPrice(TextBox1.Text).ToString()End Sub
End Class

当使用Microsoft Visual Studio工具栏上的“开始”按钮执行并运行上述代码时,浏览器中将打开以下页面:

输入符号并单击获取价格按钮以获得硬编码的价格:


未完待续,下一章节,つづく

VB.NET 教程_04_高级教程相关推荐

  1. 高级计算机网络教程,计算机网络高级教程

    本书介绍人工智能的理论.方法和技术及其应用,除了讨论那些仍然有用的和有效的基本原理和方法之外,着重阐述一些新的和正在研究的人工智能方法与技术,特别是近期发展起来的方法和技术.此外,用比较多的篇幅论述人 ...

  2. java高级教程_Java高级教程02

    1.Java线程 1.1. 多线程和多进程 多进程:操作系统能够同时进行多个任务: 每个app(word,播放器,浏览器)可以同时运行 多线程:同一应用程序中哟多个顺序流同时执行 线程是进程中的一部分 ...

  3. 菜鸟教程C#高级教程

    C#特性(Attribute) .Net框架提供了三种预定义特性:attributeUsage.Conditional.obsolete 预定义特性AttributeUsage:预定义特性attrib ...

  4. mysql sql高级教程_SQL高级教程

    一.top子句 top子句用于规定要返回的记录的数目 并非所有数据库系统都支持top子句 # sqlserverSELECT TOP number|percent column_name(s) FRO ...

  5. matlab高级教程,【高级教程】利用高级计算软件MATLAB抠图教程

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 A=imread('lin13.bmp'); %输入淋淋图像名字 imshow(A); hold on; Threshold = 1; UniBack=[ ...

  6. python继承编程教程_Python高级教程-多重继承

    多重继承 继承是面向对象编程的一个重要的方式,因为通过继承,子类可以扩展父类的功能. Animal类的层次设计,假设要实现以下4中动物: Dog - 狗狗: Bat - 蝙蝠: Parrot - 鹦鹉 ...

  7. UltraEdit高级教程

    UltraEdit高级教程 UltraEdit 是一套功能强大的文本编辑器,可以编辑文字.Hex.ASCII码,可以取代记事本,内建英文单词检查.C++及VB 语法加亮,可同时编辑多个文件,而且即使开 ...

  8. asp.net高级教程

    asp.net高级教程(一)---asp.net , 还是asp+? 看到这个标题你可能会笑,alpha版的时候MS叫它asp+,后来出了beta1版,就改名叫asp.net了,那还不是一回事吗?你错 ...

  9. [转帖]tar高级教程:增量备份、定时备份、网络备份

    tar高级教程:增量备份.定时备份.网络备份 作者: lesca 分类: Tutorials, Ubuntu 发布时间: 2012-03-01 11:42 ė浏览 27,065 次 61条评论 一.概 ...

  10. ios cocopods 安装使用及高级教程

    CocoaPods简介 每种语言发展到一个阶段,就会出现相应的依赖管理工具,例如Java语言的Maven,nodejs的npm.随着iOS开发者的增多,业界也出现了为iOS程序提供依赖管理的工具,它的 ...

最新文章

  1. HDU 2282 Chocolate (最小费用最大流)
  2. rmi 反序列化漏洞_提醒:Apache Dubbo存在反序列化漏洞
  3. 使用公式给参数赋默认初始值
  4. php 语义解析,有关语义分析的文章推荐6篇
  5. ThreadLocal封装SimpleDateFormat
  6. 权限不同,设置标签绑定的事件生效与不生效(使事件不起作用)
  7. day28 socketserver
  8. 视觉SLAM——ceres非线性最小二乘求解器
  9. fatjar: eclipse导出工具
  10. TCPIP详解卷一概述 学习记录 2020/4/13
  11. php 同义词词库,php如何实现同义词替换
  12. solid converter pdf解锁密码_pdf转换word文档怎么操作
  13. 义隆循环左移c语言,二进制除法运算(义隆单片机)
  14. Firefox设置中文
  15. Domino M-Series 设置说明
  16. 使用Termux在安卓手机上搭建本地Git服务器
  17. 手撸SSO单点登录(五)登录验证-OA系统页面刷新或者跳转新OA系统页面
  18. arc242||C - 1111gal password(希望下次能带脑子写题...)
  19. 如果要你向别人推荐电影,你最先想到的是那些呢?
  20. 采用蒙特卡罗方法生成zipf分布随机数据

热门文章

  1. 极限精简服务器系统,极限精简斐讯T1/N1 极客开发者强迫症福音6.25
  2. CAD导出JPG如何控制转换质量?
  3. 红宝书(javascirpt高级程序设计)学习笔记(一)
  4. weibinv matlab,利用MATLAB进行夫琅和费衍射
  5. DELPHI中MessageBox的用法
  6. c语言延时时间计算器,rc延时电路延时时间计算公式
  7. 视频教程 C语言全套视频教程(已更新完毕
  8. 爱立信面试前的GitHub项目如何上传
  9. 鸿蒙HMS大势渐成,P40系列开启华为终端新征程
  10. 思科交换机命令大全 一