我有一个非常混乱的 Google 表格。在某些单元格中,有多个电子邮件地址、多个姓名、多个电话号码等。原始数据
我想将具有多个电子邮件地址的单元格拆分为不同的行,其他列的数据完全相同。像这样的东西: 清洁过的床单
我使用了一个脚本,我在 StackOverflow 上找到了另一个答案,但是,该脚本仅在电子邮件地址之间有回车符或空格时才有效。问题是表格非常不一致,所以我的电子邮件用“;”分隔 有的用回车符或空格隔开。
你知道我如何可以轻松快速地清理这些数据并将这些电子邮件分成不同的行吗?任何帮助将不胜感激。
这是我使用的脚本:
// Main of this script.
function result(range) {
var output = [];
for (var i in range) {
var celLen = 1;
var c1 = range[i].map(function(e, i){
var cell = e.toString().split("\n"); // Modified
var len = cell.length;
if (len == 1) {
return cell[0];
} else if (len > 1) {
celLen = celLen > len ? celLen : len;
var t2 = [];
for (var k=0; k<cell.length; k++) {
t2.push(cell[k]);
}
return t2;
}
});
var c2 = c1.map(function(e, i){
var r = [];
if (!Array.isArray(e)) {
for (var k=0; k<celLen; k++) {
r.push(e);
}
} else {
for (var k in e) {
r.push(e[k]);
}
if (e.length < celLen) {
for (var m=0; m<celLen - e.length; m++) {
r.push("");
}
}
}
return r;
});
var c3 = c2[0].map(function(e, i){return c2.map(function(f, j){return c2[j][i]})});
Array.prototype.push.apply(output, c3);
}
return output;
}
// For testing this script.
function main() {
var ss = SpreadsheetApp.getActiveSheet();
var data = ss.getDataRange().getValues();
var r = result(data);
ss.getRange(ss.getLastRow() + 1, 1, r.length, r[0].length).setValues(r);
} ```