【问题标题】:Google Sheet to Excel conversion - Treating "" as zeroGoogle 表格到 Excel 的转换 - 将“”视为零
【发布时间】:2019-10-23 19:34:27
【问题描述】:

我需要将几个(数百个)Google 表格转换为 Excel。为了整洁起见,由于=IF(condition is true;calculation;"") 之类的公式,原始工作表中的许多单元格中都有“”。

Google 表格将“”视为零。例如,A1=""、B1=3、A1+B1=3。

当将此工作表导出到 Excel 时,Excel 会给出 A1+B1 的数据类型错误。如果将 A1 更改为空白或 0,错误就会消失。

在这种情况下,有没有一种简单的方法可以让 Excel 像 Google Sheet 一样工作?

【问题讨论】:

  • 您可以使用 SUM(): =SUM(A1,B1) 将忽略文本。大多数公式都会这样做,有些不会,但大多数。否则,除了将所有"" 更改为0 并使用隐藏0 以显示为空白的自定义数字格式之外,Excel 无法做到这一点。
  • 谢谢斯科特。我真的希望我不必遍历所有表格并开始调整公式和数字格式。这可能需要我几天的繁琐工作:-(
  • 你能修复谷歌中的公式以将错误结果更改为 0 而不是“”吗?如果您在公式中将错误结果更改为“false”(不在引号中),则它应导入为 0。
  • 谢谢蒂姆。是的,我当然可以做这种事情。但是,问题是我必须转换数百张工作表,其中许多工作表相当大,有许多复杂的公式。这应该是一个简单的过程,由转换过程或 Excel 在计算中处理“”的方式处理。

标签: excel google-sheets


【解决方案1】:

André,您可以在电子表格的每个工作表上应用此脚本,以删除公式中的“”,这样对工作表和 Excel 都没有影响

function myFunction() {

var feuilles = SpreadsheetApp.getActiveSpreadsheet().getSheets()
feuilles.forEach(function(feuille){
 var cellules = feuille.getRange(1,1,feuille.getLastRow(),feuille.getLastColumn())
  var formules = cellules.getFormulas()
  const regex = new RegExp(';["]{2}', 'g')
  var li = 0
  formules.forEach(function(ligne){
    li++
    var co = 0
    ligne.forEach(function(formule){
      co++
      try{
        if(regex.test(formule)){
          formule = formule.replace(regex,';')
          feuille.getRange(li,co).setFormula(formule)
        }
      }
      catch(e){}
    })
  })
})
  
}

【讨论】:

    猜你喜欢
    • 2020-07-19
    • 1970-01-01
    • 2019-12-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-03-21
    • 1970-01-01
    相关资源
    最近更新 更多