ОБНОВЛЕНИЕ: это верно, только если вы используете ONLYOFFICE вместо MS Excel.
На самом деле все ответы, представленные здесь, а также в принятом, есть поток. Поток заключается в том, что всякий раз, когда у вас есть пустая ячейка в excel и копируете ее, в буфере обмена у вас есть 2 символа табуляции рядом друг с другом, поэтому после разделения вы получаете один дополнительный элемент в массиве, который затем появляется как дополнительная ячейка в этой строке и перемещает все остальные ячейки на одну. Поэтому, чтобы избежать этого, вам в основном нужно заменить все символы двойной табуляции (только табуляции рядом друг с другом) в строке одним символом табуляции и только затем разделить его.
Обновленная версия jsfiddle @ userfuser здесь, чтобы исправить эту проблему путем фильтрации вставленных данных с помощью removeExtraTabs
http://jsfiddle.net/sTX7y/794/
function removeExtraTabs(string) {
return string.replace(new RegExp("\t\t", 'g'), "\t");
}
function generateTable() {
var data = removeExtraTabs($('#pastein').val());
var rows = data.split("\n");
var table = $('<table />');
for (var y in rows) {
var cells = rows[y].split("\t");
var row = $('<tr />');
for (var x in cells) {
row.append('<td>' + cells[x] + '</td>');
}
table.append(row);
}
$('#excel_table').html(table);
}
$(document).ready(function() {
$('#pastein').on('paste', function(event) {
$('#pastein').on('input', function() {
generateTable();
$('#pastein').off('input');
})
})
})