【问题标题】:How to replace newline or soft linebreak (ctrl+enter) in Google doc app script?如何在 Google doc app 脚本中替换换行符或软换行符(ctrl+enter)?
【发布时间】:2019-05-16 04:17:22
【问题描述】:

我有一个工作模板(Google Doc),并且有以下模式的变量要替换为值

{{基本工资_.说明}}
{{OT1.5.Description}}
{{MEL ALW.Description}}
{{OST ALW.Description}}
{{TRV ALW.Description}}
{{ADV SAL.Description}}

注意:我在 google doc 中使用软换行符(ctrl+enter),因为我无法检测到正常的换行符模式“\n”、“\n”、“\ r\n" 但我的结果总是很奇怪,因为有些行需要替换为正确的描述,但有些需要完全无效(删除整个 {{pattern}} 以及换行符以避免空行)

我尝试了多种 REGEX 模式,搜索了在线论坛 https://github.com/google/re2/wiki/Syntax
Eliminate newlines in google app script using regex
Use RegEx in Google Doc Apps Script to Replace Text

并确定只有软换行是唯一的处理方法(识别模式 \v。请检查我的示例代码,因为模式替换不能按预期工作。

// code block 1
var doc = DocumentApp.openById(flPayslip.getId());
var body = doc.getBody();
body.replaceText("{{BASIC SALARY_.Description}}", "Basic Salary");
body.replaceText("{{OST ALW.Description}}", "Outstation Allowance");
// code block 2
var doc = DocumentApp.openById(flPayslip.getId());
var body = doc.getBody();
body.replaceText("{{BASIC SALARY_.Description}}", "Basic Salary");
body.replaceText("{{OST ALW.Description}}", "Outstation Allowance");
body.replaceText("{{.*}}\\v+", "");  // to replace soft linebreak

代码块1的实际结果

基本工资
{{OT1.5.Description}}
{{MEL ALW.Description}}
外派津贴
{{TRV ALW.Description}}
{{ADV SAL.Description}}

代码块2的实际结果:

基本工资

问题:实际结果“Outstation Allowance”已从正则表达式替换中删除。

预期结果

基本工资
外派津贴

我应该在我的代码中使用什么正确的正则表达式模式?

【问题讨论】:

  • 我能问你的问题吗?在你的实际情况下,比如{{BASIC SALARY_.Description}}是不是被一些文字包围了?还是{{###}}的值没有被文本包围,每个值只放在一个段落中?为了正确理解您的情况,能否提供您要使用的示例文档?当然,请删除您的个人信息。
  • 这是我的实际模板文件docs.google.com/document/d/…,它是一个简化版。我的期望是某些项目(例如OT,它包括单位),它变成{{OT1.5.Description}}({{OT1.5.Unit}}),替换结果是“OT1.5(3 )” 而不仅仅是“OT1.5”。如果可以为某些项目动态替换为“单位”,那就太好了! :)
  • 感谢您的回复。很高兴您的问题得到解决。

标签: regex google-apps-script google-docs-api


【解决方案1】:

试试

body.replaceText("{{[^\\v]*?}}\\v+", "");  // No \v inside `{{}}` and  not greedy`?`

当您使用{{.*}} 时,.* 匹配第一个 {{ 和最后一个 }} 之间的所有内容

基本工资
{{

OT1.5.描述}}
{{MEL ALW.Description}}
外派津贴
{{TRV ALW.Description}}
{{ADV SAL.描述

}}

【讨论】:

  • 它像魔法一样工作!!!谢谢@TheMaster!感谢魔术代码,我仍然试图理解它。如果我想让我的模板更有意义,一些收入项目需要显示单位,例如{{OT1.5.Description}} ({{OT1.5.Unit}}) 不起作用。这是我的模板drive.google.com/… 再次感谢您的帮助!
  • @Weilis 请提出这样一个经过充分研究的新问题。
  • 对不起,如果我错了,请纠正我。我应该创建一个单独的线程,而我的问题的变化很小?无论如何,我找到了摆脱额外更改的方法。通过在您鼓舞人心的代码之后添加下面的行并且它起作用了。 body.replaceText("{{[^\\v]*?}} \({{[^\\v]*?}}\)\\v+", "");
  • @Weilis 是的,但只关注新问题。事实上,我不明白你的新问题。而且我不想访问外部链接。
  • @Tanaike 谢谢。
猜你喜欢
  • 2021-12-31
  • 1970-01-01
  • 2013-04-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-10-01
  • 2012-04-08
  • 2013-05-10
相关资源
最近更新 更多