Loading [MathJax]/jax/input/TeX/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >我应该为此使用解析器/词法器吗?

我应该为此使用解析器/词法器吗?
EN

Stack Overflow用户
提问于 2009-12-17 16:31:32
回答 5查看 283关注 0票数 0

我想知道像ANTLR这样的工具是否会被批准来解析这些规则,或者它是过火了,我应该创建我自己的解析器。

这是为了解析别人的格式,所以我不能改变它。这是为了好玩和练习,所以不要太烦恼。这些是用来描述语言中语音变化的规则。我会引用原作者的话

声音转换格式 希望任何语言学家都能熟悉规则的格式。例如,这里有一个声音变化: c/g/V_V 这个规则说要在元音之间改变c到g。(我们将在下面介绍如何推广这条规则。) 更广泛地说,一个合理的变化是这样的: x/y/z 其中x是要改变的东西,y是它要改变的东西,z是环境。 Z部件必须始终包含下划线_,表示更改的部分。就这样,就像在 gn/nh/_ 它告诉程序无条件地用nh替换gn。 字符#代表单词的开头或结尾。所以 u/o/_# 意思是用o代替u,但只在单词的末尾。 中间(y)部分可以是空白的,如 s//_# 这意味着当s结束一个单词时,它就被删除了。 变量 环境(z部分)可以包含变量,如上面的V。这些都是在文件顶部定义的。我用大写字母来做这个,虽然这不是一个要求。变量只能是一个字符长。您可以定义声明声音更改所需的任何变量。例如,你可以把S定义为任意的停止,或者定义为任何日冕的K,或者什么的。 所以变量的定义和规则 F=ie c/i/F_t 意思是c在前元音之后和a t之前改变为i。 您也可以在前两部分中使用变量。例如,假设您定义了 S=ptc Z=bdg S/Z/V_V 这意味着,在元音之间,停止ptc改变为它们的浊音对应物bdg。在这种用法中,变量必须对应1:1-p= b,t= d,等等。替换变量(这里Z)中的每个字符都给出了输入变量(这里S)中每个字符的转换值。确保两个变量的定义是相同的长度! 还可以将变量设置为固定值或删除。例如。 Z//V_V 删除元音之间的浊音停止。 规则顺序 规则适用于它们所列的顺序。所以,用歌剧这个词和规则 p/b/V_V e//C_rV 第一个规则发出p的声音,导致obera;第二个规则删除辅音和中间音r之间的e,从而导致obra。 -p命令行参数可以帮助调试规则,因为它会使输出准确地显示应用于每个单词的规则。 环境中的可选元素 环境中的一个或多个元素可以用括号标记为可选元素。例如。 u/ü/_C(C)F 当它后面跟着一个或两个辅音,然后是一个前元音时,就把u改为ü。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2009-12-17 16:51:25

虽然您的语言很简单,但是使用ANTLR有很多优点。

  1. 速度。生成的代码非常快。
  2. 简约。由于您使用的是较高级别的语言,所以小的语法更改成本更低、更复杂。
  3. 可扩展性由于您使用的是较高级别的语言,添加功能是一项成本较低的活动。

是的,你需要学习抗病毒药物疗法。如果您的语法有歧义,您将需要了解shift(减少冲突和减少冲突)。这可能是值得花的时间。

许多问题是词汇扫描或解析问题。了解如何创建词汇扫描器和解析器是一项有用的技能。

票数 2
EN

Stack Overflow用户

发布于 2009-12-19 02:29:55

如果您的问题仅仅是解析规则,那么您可能不需要解析器生成器。就像你说的,所有规则都是X/Y/Z格式,在任何语言中分裂它们都是非常容易的。

如果正如我所怀疑的那样,您正在创建一个工具来读取规则并将它们应用到文件中,那么问题就会复杂得多。

若要使用解析器生成器,假设您有一组固定的规则,则必须以解析器生成器所需的格式将它们转换为一组语法生成,并将它们提供给它。通过编译解析器生成器的输出,您将得到一个能够根据这些规则翻译文件的程序。考虑到您的规则似乎是上下文敏感的(c/g/V_V),我建议寻找提供GLR (Tomita解析器)或钉住 (解析表达式语法)的解析器生成器。

如果您的规则集不是固定的,并且您的程序必须与文件一起读取它们才能进行转换,那么您真正需要的是一个文本转换引擎。在这种情况下,您将把X/Y/Z规则转换成适当的格式,并将其与源文件一起提供给引擎。

假设您不想编写自己的引擎,您可以查看通用宏处理器(M4盖马,.)或者直接解释语言(珀尔Lua,.)来帮助你。

例如,在Gema中,可以将c/g/V_V转换为:

代码语言:javascript
运行
AI代码解释
复制
<vowel>c<vowel>=$1g$2
vowel:a=a;e=e;i=i;o=o;u=u;=@terminate

在Lua in:

代码语言:javascript
运行
AI代码解释
复制
function rule1(s)
  return (string.gsub(s,"([aeiou])c([aeiou])","%1g%2"))
end

最后,它实际上取决于您是否需要为给定的一组规则创建某种东西,或者您是否需要能够读取和解释任何一组规则。

当然,在任何情况下,您都必须解析您的规则才能以正确的格式转换它们,但是,正如我在一开始所说的,语法在我看来非常简单,不能证明使用解析器生成器是合理的。

票数 1
EN

Stack Overflow用户

发布于 2009-12-17 16:37:45

在我看来,使用解析工具太过分了,特别是如果您还不熟悉可以完成这项工作的工具。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1925557

复制
相关文章
【C#】使用IExtenderProvider为控件添加扩展属性,像ToolTip那样
- 文中的“控件”一词是广义上的说法,泛指包括ToolStripItem、MenuItem在内单个界面元素,并不特指继承自Control类的狭义控件
AhDung
2018/09/13
1.7K0
【C#】使用IExtenderProvider为控件添加扩展属性,像ToolTip那样
[Flutter Widget]Tooltip
在前面的文章中我们讲到了Wrap的用法,介绍了Flutter中的流式布局,在文章的最后让大家实现如下效果:
flyou
2018/10/16
3.2K0
bootstrap tooltip
<!doctype html> <html> <head> <meta charset="utf-8"> <title>联想控股</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link href="css/bootstrap.css" rel="stylesheet" type="text/css"> <script src="http://code.jquery.com/jquery.js"></script> <script src="js/bootstrap.min.js"></script> <script> ('[data-toggle="tooltip"]').tooltip() }) </script> </head> <body> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="top" title="Tooltip on top"> Tooltip on top </button> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="right" title="Tooltip on right"> Tooltip on right </button> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="bottom" title="Tooltip on bottom"> Tooltip on bottom </button> <button type="button" class="btn btn-secondary" data-toggle="tooltip" data-placement="left" title="Tooltip on left"> Tooltip on left </button> </body> </html>
用户5760343
2019/07/07
1.4K0
jQuery Tooltip
jQuery Tooltip 插件取代了原生的工具提示框,让它们可自定义,您只需要调整它们的内容、位置和外观即可。
陈不成i
2021/07/23
1.2K0
前端实现tooltip
鼠标悬浮在问号图标上, 下方展示提示文本..tooltip { margin: 8px; padding: 8px; border: 1px solid #CCCCCC; background-color: #F6DBB3; position: absolute; z-index: 2;}.arrow-div { position: absolute; z-index: 3; display: inline-block; border-top: 1
code-x
2022/11/17
1.1K0
ElementUI中动态修改tooltip内容
在博客开发过程中,遇到这样一个需求:随着用户发布文章数量增多,每一类文章的数量在动态变化,需要在tooltip中动态修改文章数量,像下面这张图:
Marigold
2022/06/17
3.7K0
ElementUI中动态修改tooltip内容
扩展ToolBarManager、ListView和Grid控件以实现气球式的ToolTip
infragistics是全球领先的UI工具和用户体验的专家,Infragistics开发了一系列的炫目的Windows、Web、WPF和Silverlight控件,相信很多人在使用它们。我们现在的项目就在使用Infragistics的Windows Form控件集。虽然这些控件功能强大,也不可能满足你所有的需求,尤其是那些比较苛刻的最终用户的需求。比如,我们最近就接收到这样一个变态的需求:让所以菜单项、工具栏按钮、网格单元的ToolTip以气球式的样式显示。最终,我不得不通过对现有控件的扩展实现这个要求。
蒋金楠
2018/01/16
1.3K0
扩展ToolBarManager、ListView和Grid控件以实现气球式的ToolTip
Angular 自定义指令 Tooltip
Yeah,关注我的读者应该知道,上一篇文章了解 Angular 开发的内容,我们已经概览了 Angular 的相关内容。在自定义指令的部分,我们已经能够实现编写,但是,在实际场景中,我们还需要标准化的管理。
Jimmy_is_jimmy
2022/04/15
1.5K0
Angular 自定义指令 Tooltip
BOOtstrap源码分析之 tooltip、popover
一、tooltip(提示框) 源码文件: Tooltip.js Tooltip.scss 实现原理: 1、获取当前要显示tooltip的元素的定位信息(top、left、bottom、right、width、height等) 2、计算tooltip的位置,是top、left、bottom、right其中一个 3、然后根据计算的位置值,运算出坐标值 4、给tooltip应用坐标值 源码分析: 1、ownerDocument:文档;包含两个对象:<DocType>、documentElement(根节点) 2
sam dragon
2018/01/17
2K0
BOOtstrap源码分析之 tooltip、popover
tooltip(title美化)教程——jquery的特效
浏览器自带的alt和title提示太丑了,所以我们需要美化一下,百度有许多,不过对我们这些小白来说很难。 首先复制下面代码到网站底部: var sweetTitles = { x: 10, y: 20, tipElements: "a,span,img,div ", noTitle: false, init: function() { var b = this.noTitle; $(this.tipElements).each(function() { $(this).m
Youngxj
2018/06/06
5.5K0
CListCtrl实现tooltip信息提示
EnableToolTips(TRUE); m_tooltip.Create(this); m_tooltip.SetMaxTipWidth(500); m_tooltip.Activate(TRUE);
全栈程序员站长
2022/09/09
1.3K0
Bootstrap3 修改tooltip默认的颜色
.tooltip-inner { background-color: #f7df4b; color: black; } .tooltip.top .tooltip-arrow { border-top-color: #f7df4b; } .tooltip.bottom .tooltip-arrow { border
kirin
2021/01/20
1K0
echarts tooltip trigger: 'axis'没有作用
今天在使用echarts3柱形图时遇到一个问题,鼠标略过横轴时没有如期出现提示信息,相关设置如下:
johnhuster的分享
2022/03/28
2.1K0
Flutter基础widgets教程-Tooltip篇
1 Tooltip 一个文本提示工具,帮助解释一个按钮或其他用户界面,当widget长时间按下时(当用户采取其他适当操作时)显示一个提示标签 2 构造函数 Tooltip({ Key key, @required this.message, this.height, this.padding, this.margin, this.verticalOffset, this.preferBelow, this.excludeFromSemantic
青年码农
2020/10/10
9050
Flutter基础widgets教程-Tooltip篇
flask popper对tooltip做美化(flask 38)
<small data-toggle="tooltip" data-placement="top" data-timestamp="{{ message.timestamp.strftime('%Y-%m-%dT%H:%M:%SZ') }}" data-delay="500"> {{ moment(message.timestamp).fromNow(refresh=True) }} </small> <script type="text/javascript" src="{{ url_for('static', filename='js/popper.min.js') }}"></script>
用户5760343
2019/08/13
7840
【Flutter 组件集录】Tooltip 与 Overlay
今天是八月更文的最后一天,带大家看一下 Tooltip 组件的实现,从而引出 Overlay 组件的使用方式。 Tooltip 组件主要的作用是在鼠标悬浮或长按手势下触发消息提示。它继承自 StatefulWidget ,其中必须传入 String 类型的 message ,还有很多其他的参数用于配置。
张风捷特烈
2022/03/18
1.8K0
【Flutter 组件集录】Tooltip 与 Overlay
tooltip.css-2.0文档
只需在页面中引入"tooltip.css"或“tooltip.min.css”文件即可。
用户6167509
2019/09/04
7770
C#-ToolTIp和Popup简单使用
很多时候我们需要做一个提示框,来给用户说明这个元素的作用,比如鼠标移动到哪个元素上面,显示一个弹出框并显示这个元素的相关介绍,想到提示内容,我们很容易想到toolip和Popup,接下来就来分别是用一下这两个控件。
kdyonly
2023/03/03
1.2K0
基于bootstrap3响应式Tooltip提示插件
ggtooltip.js是一款非常实用的基于bootstrap 3.X的jQuery tooltip提示插件。该bootstrap jQuery tooltip插件实用简单,支持在4个方向上像素tooltip信息,支持修改tooltip的背景色、前景色和边框颜色。 该jQuery tooltip插件实用简单,支持在4个方向上像素tooltip信息,支持修改tooltip的背景色、前景色和边框颜色。它的特点有:
小狐狸说事
2022/12/01
1.1K0
基于 HTML5 Canvas 的拓扑组件 ToolTip 应用
ToolTip 效果是网页制作中常见的使用特效。当用户将鼠标悬浮在某个控件上时,ToolTip 显示并向用户展示相应的提示信息;当鼠标离开时,ToolTip 隐藏。一般情况下,我们使用 ToolTip 只是显示一句话或几个字,其实我们还可以展示很多信息。而今天的重点则是通过 Hightopo 的 HT for Web 产品来制作多种样式的 ToolTip。
HT for Web
2020/03/26
1.3K0

相似问题

仅使用XAML切换Button控件的ToolTip

22

控件WPF上的ToolTip

31

C# ToolTip问题

12

ToolTip与Popup (WPF控件)

20

正确更新控件上的ToolTip

14
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档