如何在 Google doc app 脚本中替换换行符或软换行符 (ctrl+enter)?
How to replace newline or soft linebreak (ctrl+enter) in Google doc app script?
我有一个工作模板(Google 文档)并且具有以下模式的变量要替换为值
{{BASIC SALARY_.Description}}
{{OT1.5.Description}}
{{MEL ALW.Description}}
{{OST ALW.Description}}
{{TRV ALW.Description}}
{{ADV SAL.Description}}
注意: 我在 google 文档中使用软换行符 (ctrl+enter),因为我无法检测到正常的换行符模式 "\n ", "\n", "\r\n" 但我的结果总是很奇怪,因为有些行需要替换为正确的描述,但有些需要完全无效(删除整个 {{pattern}} 连同换行符避免空行)
我尝试了多种 REGEX 模式,google在线论坛
https://github.com/google/re2/wiki/Syntax
并找出只有软换行符是处理 (identify pattern \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 的实际结果
Basic Salary
{{OT1.5.Description}}
{{MEL ALW.Description}}
Outstation Allowance
{{TRV ALW.Description}}
{{ADV SAL.Description}}
代码块 2 的实际结果:
Basic Salary
问题:实际结果 "Outstation Allowance" 已从正则表达式替换中删除。
预期结果
Basic Salary
Outstation Allowance
我应该在我的代码中使用什么正确的正则表达式模式?
尝试
body.replaceText("{{[^\v]*?}}\v+", ""); // No \v inside `{{}}` and not greedy`?`
当您使用 {{.*}}
时,.*
匹配第一个 {{
和最后一个 }}
之间的所有内容
Basic Salary
{{
OT1.5.Description}}
{{MEL ALW.Description}}
Outstation Allowance
{{TRV ALW.Description}}
{{ADV SAL.Description
}}
我有一个工作模板(Google 文档)并且具有以下模式的变量要替换为值
{{BASIC SALARY_.Description}}
{{OT1.5.Description}}
{{MEL ALW.Description}}
{{OST ALW.Description}}
{{TRV ALW.Description}}
{{ADV SAL.Description}}
注意: 我在 google 文档中使用软换行符 (ctrl+enter),因为我无法检测到正常的换行符模式 "\n ", "\n", "\r\n" 但我的结果总是很奇怪,因为有些行需要替换为正确的描述,但有些需要完全无效(删除整个 {{pattern}} 连同换行符避免空行)
我尝试了多种 REGEX 模式,google在线论坛
https://github.com/google/re2/wiki/Syntax
并找出只有软换行符是处理 (identify pattern \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 的实际结果
Basic Salary
{{OT1.5.Description}}
{{MEL ALW.Description}}
Outstation Allowance
{{TRV ALW.Description}}
{{ADV SAL.Description}}
代码块 2 的实际结果:
Basic Salary
问题:实际结果 "Outstation Allowance" 已从正则表达式替换中删除。
预期结果
Basic Salary
Outstation Allowance
我应该在我的代码中使用什么正确的正则表达式模式?
尝试
body.replaceText("{{[^\v]*?}}\v+", ""); // No \v inside `{{}}` and not greedy`?`
当您使用 {{.*}}
时,.*
匹配第一个 {{
和最后一个 }}
Basic Salary
{{OT1.5.Description}}
{{MEL ALW.Description}}
Outstation Allowance
{{TRV ALW.Description}}
{{ADV SAL.Description}}