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的更多相关文章

  1. Swift Playground词法分析器DEMO

    正在看极客时间宫文学老师的编译原理之美,用swift playground写了一个第二课"int age >= 45"的词法解析DEMO 为了保持原课程代码,DEMO用了顺序 ...

  2. 通过一个demo了解Redux

    TodoList小demo 效果展示 项目地址 (单向)数据流 数据流是我们的行为与响应的抽象:使用数据流能帮我们明确了行为对应的响应,这和react的状态可预测的思想是不谋而合的. 常见的数据流框架 ...

  3. 很多人很想知道怎么扫一扫二维码就能打开网站,就能添加联系人,就能链接wifi,今天说下这些格式,明天做个demo

    有些功能部分手机不能使用,网站,通讯录,wifi基本上每个手机都可以使用. 在看之前你可以扫一扫下面几个二维码先看看效果: 1.二维码生成 网址 (URL) 包含网址的 二维码生成 是大家平时最常接触 ...

  4. 在线浏览PDF之PDF.JS (附demo)

    平台之大势何人能挡? 带着你的Net飞奔吧!:http://www.cnblogs.com/dunitian/p/4822808.html#skill 下载地址:http://mozilla.gith ...

  5. 【微框架】Maven +SpringBoot 集成 阿里大鱼 短信接口详解与Demo

    Maven+springboot+阿里大于短信验证服务 纠结点:Maven库没有sdk,需要解决 Maven打包找不到相关类,需要解决 ps:最近好久没有写点东西了,项目太紧,今天来一篇 一.本文简介 ...

  6. vue双向数据绑定原理探究(附demo)

    昨天被导师叫去研究了一下vue的双向数据绑定原理...本来以为原理的东西都非常高深,没想到vue的双向绑定真的很好理解啊...自己动手写了一个. 传送门 双向绑定的思想 双向数据绑定的思想就是数据层与 ...

  7. Android Studio-—使用OpenCV的配置方法和demo以及开发过程中遇到的问题解决

    前提: 1.安装Android Studio(过程略) 2.官网下载OpenCV for Android 网址:http:opencv.org/downloads.html 我下载的是下图的版本 3. ...

  8. iOS之ProtocolBuffer搭建和示例demo

    这次搭建iOS的ProtocolBuffer编译器和把*.proto源文件编译成*.pbobjc.h 和 *.pbobjc.m文件时,碰到不少问题! 搭建pb编译器到时没有什么问题,只是在把*.pro ...

  9. 钉钉开放平台demo调试异常问题解决:hostname in certificate didn't match

    今天研究钉钉的开放平台,结果一个demo整了半天,这帮助系统写的也很难懂.遇到两个问题: 1.首先是执行demo时报unable to find valid certification path to ...

随机推荐

  1. BITED数学建模七日谈之三:怎样进行论文阅读

    前两天,我和大家谈了如何阅读教材和备战数模比赛应该积累的内容,本文进入到数学建模七日谈第三天:怎样进行论文阅读. 大家也许看过大量的数学模型的书籍,学过很多相关的课程,但是若没有真刀真枪地看过论文,进 ...

  2. make subversion时出现neon报错 及 svn其他问题汇总(3ge )

    在make subvision时,出现以下错误提示: /usr/local/src/neon-0.29.6/src/ne_auth.c:781: undefined reference to`ne__ ...

  3. 《Java数据结构与算法》笔记-CH4-4循环队列

    /** * 循环队列 */ class Queue { private int maxSize; private long[] queue; private int front; private in ...

  4. Android Studio 中SDK Manager的设置

    android studio 代码块左边的缩进对齐线的颜色修改:  Settings -> Editor -> Colors & Fonts -> General -> ...

  5. InternetOpenA

    [ilink32 Error] Error: Unresolved external 'InternetOpenA' referenced from  ..\WIN32\DEBUG\NATIVEXML ...

  6. 【转】Hive学习路线图

    原文博客出自于:http://blog.fens.me/hadoop-hive-roadmap/ 感谢! Hive学习路线图 Hadoop家族系列文章,主要介绍Hadoop家族产品,常用的项目包括Ha ...

  7. HD2046骨牌铺方格

    骨牌铺方格 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...

  8. keil中如何得知所编译程序所占空间大小?

    keil编译后出现Program Size: data=21.0 xdata=0 code=2231. 这表明 data= 21.0  数据储存器内部RAM占用21字节, xdata=0     数据 ...

  9. msyql数据库主从架构

    在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一.尤其是在大规模系统中,数据库集群已经成为必备的配置之一.集群的好处主要有:查询负载.数据库复制备份等. MySQL数据库支持数据库的主 ...

  10. CCF 201312-3 最大的矩形 (暴力,离散化)

    问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1 ≤ i ≤ n)个矩形的高度是hi.这n个矩形构成了一个直方图.例如,下图中六个矩形的高度就分别是3, 1, 6, 5, 2, 3 ...