AKTUALIZACJA: jest to prawdą tylko wtedy, gdy używasz ONLYOFFICE zamiast MS Excel.
Właściwie jest przepływ we wszystkich udzielonych tutaj odpowiedziach, a także w zaakceptowanej. Przepływ jest taki, że za każdym razem, gdy masz pustą komórkę w programie Excel i kopiujesz ją, w schowku masz 2 znaki tabulacji obok siebie, więc po podzieleniu otrzymujesz jeden dodatkowy element w tablicy, który następnie pojawia się jako dodatkowa komórka w tym wierszu i przesuwa wszystkie inne komórki o jeden. Aby tego uniknąć, w zasadzie musisz zamienić wszystkie podwójne znaki tabulacji (tylko tabulatory obok siebie) w ciągu na jeden znak tabulacji i dopiero wtedy go podzielić.
Zaktualizowana wersja jsfiddle @ userfuser jest tutaj, aby naprawić ten problem, filtrując wklejone dane za pomocą 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');
})
})
})