词法分析器Demo
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace LexerDemo
{
public enum TokenType
{
Word,
String,
Number,
SplitChar,
EscChar,
YearFlag,
MonthFlag,
DayFlag,
HourFlag,
MinutFlag,
SecondFlag
}
public class Token
{
public string Text;
public TokenType Kind;
public int Len;
public Token(TokenType type)
{
Text = string.Empty;
Len = 0;
Kind = type;
}
}
public class Lexer
{
public Token ReadNumber(string text, int pos)
{
Token t = new Token(TokenType.Number);
for (int i = pos; i < text.Length; i++)
{
char c;
c = text[i];
if (char.IsNumber(c) != true)
{
break;
}
t.Text += c;
t.Len++;
}
return t;
}
public Token ReadToken(string text, int pos, char prefix)
{
Token t = new Token(TokenType.Word);
for (int i = pos; i < text.Length; i++)
{
char c;
c = text[i];
if (c != prefix)
{
break;
}
t.Text += c;
t.Len++;
}
return t;
}
public Token ReadSplitOperater(string text, int pos, char prefix)
{
Token t = new Token(TokenType.Word);
for (int i = pos; i < pos+1; i++)
{
char c;
c = text[i];
if (c != prefix)
{
break;
}
t.Text += c;
t.Len++;
}
return t;
}
public Token ReadSplitString(string text, int pos)
{
Token t = new Token(TokenType.SplitChar);
for (int i = pos; i < text.Length; i++)
{
char c;
c = text[i];
if (c != '#')
{
break;
}
t.Text += c;
t.Len++;
}
return t;
}
public IEnumerable<Token> Parse(string line)
{
for (int i = 0; i < line.Length; i++)
{
char c = line[i];
Token token = null;
if (Char.IsNumber(c) == true)
{
token = ReadNumber(line, i);
}
else if (c == 'y')
{
token = ReadToken(line, i, c);
token.Kind = TokenType.YearFlag;
}
else if (c == 'm')
{
token = ReadToken(line, i, c);
token.Kind = TokenType.MonthFlag;
}
else if (c == 'd')
{
token = ReadToken(line, i, c);
token.Kind = TokenType.DayFlag;
}
else //记录分隔符,也就是说除了以上的字符,其他均看做分隔符
{
token = ReadToken(line, i, c);
token.Kind = TokenType.SplitChar;
// continue;
}
i += token.Len - 1;
yield return token;
}
yield break;
}
}
}
/*
* 由SharpDevelop创建。
* 用户: Administrator
* 日期: 2013/9/8
* 时间: 17:27
*
* 要改变这种模板请点击 工具|选项|代码编写|编辑标准头文件
*/
using System;
using System.Collections.Generic;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
namespace LexerDemo
{
/// <summary>
/// Description of MainForm.
/// </summary>
public partial class MainForm : Form
{
public MainForm()
{
InitializeComponent();
}
void Button1Click(object sender, EventArgs e)
{
string pbmask = textBox1.Text;
string mskstr= GetPBMask(pbmask);
}
private string GetPBMask(string pbmask)
{
Lexer o = new Lexer();
IEnumerable<Token> strlist = o.Parse(pbmask);
StringBuilder sb=new StringBuilder();
List<string> tokenlist=new List<string>();
foreach (Token item in strlist)
{
tokenlist.Add(item.Text);
}
return sb.ToString() ;
}
}
}
词法分析器Demo的更多相关文章
- Swift Playground词法分析器DEMO
正在看极客时间宫文学老师的编译原理之美,用swift playground写了一个第二课"int age >= 45"的词法解析DEMO 为了保持原课程代码,DEMO用了顺序 ...
- 通过一个demo了解Redux
TodoList小demo 效果展示 项目地址 (单向)数据流 数据流是我们的行为与响应的抽象:使用数据流能帮我们明确了行为对应的响应,这和react的状态可预测的思想是不谋而合的. 常见的数据流框架 ...
- 很多人很想知道怎么扫一扫二维码就能打开网站,就能添加联系人,就能链接wifi,今天说下这些格式,明天做个demo
有些功能部分手机不能使用,网站,通讯录,wifi基本上每个手机都可以使用. 在看之前你可以扫一扫下面几个二维码先看看效果: 1.二维码生成 网址 (URL) 包含网址的 二维码生成 是大家平时最常接触 ...
- 在线浏览PDF之PDF.JS (附demo)
平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html#skill 下载地址:http://mozilla.gith ...
- 【微框架】Maven +SpringBoot 集成 阿里大鱼 短信接口详解与Demo
Maven+springboot+阿里大于短信验证服务 纠结点:Maven库没有sdk,需要解决 Maven打包找不到相关类,需要解决 ps:最近好久没有写点东西了,项目太紧,今天来一篇 一.本文简介 ...
- vue双向数据绑定原理探究(附demo)
昨天被导师叫去研究了一下vue的双向数据绑定原理...本来以为原理的东西都非常高深,没想到vue的双向绑定真的很好理解啊...自己动手写了一个. 传送门 双向绑定的思想 双向数据绑定的思想就是数据层与 ...
- Android Studio-—使用OpenCV的配置方法和demo以及开发过程中遇到的问题解决
前提: 1.安装Android Studio(过程略) 2.官网下载OpenCV for Android 网址:http:opencv.org/downloads.html 我下载的是下图的版本 3. ...
- iOS之ProtocolBuffer搭建和示例demo
这次搭建iOS的ProtocolBuffer编译器和把*.proto源文件编译成*.pbobjc.h 和 *.pbobjc.m文件时,碰到不少问题! 搭建pb编译器到时没有什么问题,只是在把*.pro ...
- 钉钉开放平台demo调试异常问题解决:hostname in certificate didn't match
今天研究钉钉的开放平台,结果一个demo整了半天,这帮助系统写的也很难懂.遇到两个问题: 1.首先是执行demo时报unable to find valid certification path to ...
随机推荐
- MATLAB将矩阵使用.txt文件格式保存
具体的命令是:用save *.txt -ascii x x为变量 *.txt为文件名,该文件存储于当前工作目录下,再打开就可以 打开后,数据有可能是以指数形式保存的. 看下面这个例子: a =[1 ...
- Hibernate学习笔记(三)Hibernate生成表单ID主键生成策略
一. Xml方式 <id>标签必须配置在<class>标签内第一个位置.由一个字段构成主键,如果是复杂主键<composite-id>标签 被映射的类必须定义对应数 ...
- 关于Bean
什么是Bean? 一个Bean 就是一个类.我们不必为制造任何的Bean而编写一些特殊的代码或者使用特殊的编程语言.事实上,我们唯一需要做的是略微地修改我们对我们方法命名的办法.方法名通知应用程序构建 ...
- 《java数据结构与算法》笔记-CH4-8栈结构实现后缀表达式计算结果
/** * 中缀表达式转换成后缀表达式: 从输入(中缀表达式)中读取的字符,规则: 操作数: 写至输出 左括号: 推其入栈 右括号: 栈非空时重复以下步骤--> * 若项不为(,则写至输出: 若 ...
- ajax 模仿百度下拉
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- 如何在Html的CSS中去除<li>标签前面小黑点,和ul、LI部分属性方法
div是很多人做网站都会用到的,但在显示效果时前面总是会有一个小黑点,这个效果很多人不想要,但又不知到如何去除,然而我们可以用以下方法来清除. 1.在CSS中写入代码.找到相关性的CSS,在..li和 ...
- 初学VSTO一问,如何添加SheetChange事件
很多初学者在学习VSTO时,觉得很迷茫,举一个简单的例子,在VBA中,添加SheetChange的事件,非常容易. 如下图所示,只需要在VBE界面,先把SheetChange事件就好了. 而认为在VS ...
- StructLayout特性
StructLayout特性 公共语言运行库利用 StructLayoutAttribute控制类或结构的数据字段在托管内存中的物理布局,即类或结构需要按某种方式排列.如果要将类传递 ...
- 设置UIButton文字大小颜色不同
_loginBtn = [[UIButton alloc]initWithFrame:CGRectMake(iconX, CGRectGetMaxY(passwordBGView.frame)+25, ...
- hdoj 5389 Zero Escape
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5389 大体题意是:有两个门A和B,还有一群人,每个人都有一个数字, 疯了一样的T..比赛的时候十连T也 ...