77

外部プラグインや API を使用せずに csv にエクスポートする必要がある表形式のデータがあります。MIME タイプを渡すメソッドを使用しましたwindow.openが、次のような問題に直面しました。

jQuery を使用して Microsoft Excel または OpenOffice がシステムにインストールされているかどうかを確認する方法

コードは、システムにインストールされているもの (OpenOffice や Microsoft Excel など) から独立している必要があります。CSV は、両方のエディターで表示されることが期待できる形式だと思います。

コード

    <html>

<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>  

<script type="text/JavaScript">
$(document).ready(function(){
    $("#btnExport").click(function(e) {
        var msg = GetMimeTypes();
        //OpenOffice
        window.open('data:application/vnd.oasis.opendocument.spreadsheet,' + $('#dvData').html());
        //MS-Excel
        window.open('data:application/vnd.ms-excel,' + $('#dvData').html());
        //CSV
        window.open('data:application/csv,charset=utf-8,' + $('#dvData').html());
        e.preventDefault();
    });
});

function GetMimeTypes () {
    var message = "";
        // Internet Explorer supports the mimeTypes collection, but it is always empty
    if (navigator.mimeTypes && navigator.mimeTypes.length > 0) {
        var mimes = navigator.mimeTypes;
        for (var i=0; i < mimes.length; i++) {
            message += "<b>" + mimes[i].type + "</b> : " + mimes[i].description + "<br />";
        }
    }
    else {
        message = "Your browser does not support this ";
       //sorry!
    }

    return ( message);
}
</script>

</head>
<body>
<div id="dvData">
<table>
    <tr>
        <th>Column One </th>
        <th>Column Two</th>
        <th>Column Three</th>
    </tr>
    <tr>
        <td>row1 Col1</td>
        <td>row1 Col2</td>
        <td>row1 Col3</td>
   </tr>
   <tr>
        <td>row2 Col1</td>
        <td>row2 Col2</td>
        <td>row2 Col3</td>
   </tr>
      <tr>
        <td>row3 Col1</td>
        <td>row3 Col2</td>
        <td>row3 Col3</td>  
   </tr>
</table>
</div>
<br/>
<input type="button" id="btnExport" value=" Export Table data into Excel " />

</body>

エラー

CSV:ブラウザで認識されない

ODS & Excel: 動作していますが、システムに Excel がインストールされているか、openoffice がインストールされている場合に、どちらを生成するかを見つけることができませんか?

IEバージョン 8 : まったく機能していません。新しいウィンドウが開き、下のスクリーンショットのようになります。

ここに画像の説明を入力

4

6 に答える 6

130

デモ

説明については、以下を参照してください。

$(document).ready(function() {

  function exportTableToCSV($table, filename) {

    var $rows = $table.find('tr:has(td)'),

      // Temporary delimiter characters unlikely to be typed by keyboard
      // This is to avoid accidentally splitting the actual contents
      tmpColDelim = String.fromCharCode(11), // vertical tab character
      tmpRowDelim = String.fromCharCode(0), // null character

      // actual delimiter characters for CSV format
      colDelim = '","',
      rowDelim = '"\r\n"',

      // Grab text from table into CSV formatted string
      csv = '"' + $rows.map(function(i, row) {
        var $row = $(row),
          $cols = $row.find('td');

        return $cols.map(function(j, col) {
          var $col = $(col),
            text = $col.text();

          return text.replace(/"/g, '""'); // escape double quotes

        }).get().join(tmpColDelim);

      }).get().join(tmpRowDelim)
      .split(tmpRowDelim).join(rowDelim)
      .split(tmpColDelim).join(colDelim) + '"';

    // Deliberate 'false', see comment below
    if (false && window.navigator.msSaveBlob) {

      var blob = new Blob([decodeURIComponent(csv)], {
        type: 'text/csv;charset=utf8'
      });

      // Crashes in IE 10, IE 11 and Microsoft Edge
      // See MS Edge Issue #10396033
      // Hence, the deliberate 'false'
      // This is here just for completeness
      // Remove the 'false' at your own risk
      window.navigator.msSaveBlob(blob, filename);

    } else if (window.Blob && window.URL) {
      // HTML5 Blob        
      var blob = new Blob([csv], {
        type: 'text/csv;charset=utf-8'
      });
      var csvUrl = URL.createObjectURL(blob);

      $(this)
        .attr({
          'download': filename,
          'href': csvUrl
        });
    } else {
      // Data URI
      var csvData = 'data:application/csv;charset=utf-8,' + encodeURIComponent(csv);

      $(this)
        .attr({
          'download': filename,
          'href': csvData,
          'target': '_blank'
        });
    }
  }

  // This must be a hyperlink
  $(".export").on('click', function(event) {
    // CSV
    var args = [$('#dvData>table'), 'export.csv'];

    exportTableToCSV.apply(this, args);

    // If CSV, don't do event.preventDefault() or return false
    // We actually need this to be a typical hyperlink
  });
});
a.export,
a.export:visited {
  display: inline-block;
  text-decoration: none;
  color: #000;
  background-color: #ddd;
  border: 1px solid #ccc;
  padding: 8px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<a href="#" class="export">Export Table data into Excel</a>
<div id="dvData">
  <table>
    <tr>
      <th>Column One</th>
      <th>Column Two</th>
      <th>Column Three</th>
    </tr>
    <tr>
      <td>row1 Col1</td>
      <td>row1 Col2</td>
      <td>row1 Col3</td>
    </tr>
    <tr>
      <td>row2 Col1</td>
      <td>row2 Col2</td>
      <td>row2 Col3</td>
    </tr>
    <tr>
      <td>row3 Col1</td>
      <td>row3 Col2</td>
      <td>row3 Col3</td>
    </tr>
    <tr>
      <td>row4 'Col1'</td>
      <td>row4 'Col2'</td>
      <td>row4 'Col3'</td>
    </tr>
    <tr>
      <td>row5 &quot;Col1&quot;</td>
      <td>row5 &quot;Col2&quot;</td>
      <td>row5 &quot;Col3&quot;</td>
    </tr>
    <tr>
      <td>row6 "Col1"</td>
      <td>row6 "Col2"</td>
      <td>row6 "Col3"</td>
    </tr>
  </table>
</div>


2017年現在

HTML5Blobを使用するようになり、フォールバックとしてURL推奨される方法として使用されます。Data URI

Internet Explorer の場合

他の答えは示唆していwindow.navigator.msSaveBlobます。ただし、 IE10/Windows 7 および IE11/Windows 10をクラッシュさせることが知られています。Microsoft Edge を使用して動作するかどうかは疑わしい ( Microsoft Edge issue ticket #10396033を参照)。

Microsoft 独自の開発者ツール/コンソールでこれを呼び出すだけで、ブラウザーがクラッシュします。

navigator.msSaveBlob(new Blob(["hello"], {type: "text/plain"}), "test.txt");


最初の回答から 4 年後、新しい IE バージョンには IE10、IE11、および Edge が含まれています。それらはすべて、Microsoft が発明した機能でクラッシュします (遅い拍手)。

navigator.msSaveBlob自己責任でサポートを追加してください。


2013年現在

通常、これはサーバー側のソリューションを使用して実行されますが、これはクライアント側のソリューションでの私の試みです。HTML を としてダンプするだけでは機能しData URIませんが、役立つ手順です。そう:

  1. テーブルの内容を有効な CSV 形式の文字列に変換します。(これは簡単な部分です。)
  2. ブラウザにダウンロードを強制します。このwindow.openアプローチは Firefox では機能しないため、<a href="{Data URI here}">.
  3. <a>タグの属性を使用してデフォルトのファイル名を割り当てますdownload。これは Firefox と Google Chrome でのみ機能します。ただの属性なので綺麗に劣化します。

ノート

互換性

ブラウザのテストには次のものが含まれます。

  • Firefox 20 以降、Win/Mac (動作)
  • Google Chrome 26 以降、Win/Mac (動作)
  • Safari 6、Mac (動作しますが、ファイル名は無視されます)
  • IE 9+ (失敗)

コンテンツのエンコーディング

CSV は正しくエクスポートされますが、Excel にインポートすると文字üが として出力されäます。Excel は値を正しく解釈しません。

導入するvar csv = '\ufeff';と、Excel 2013+ が値を正しく解釈します。

Excel 2007 との互換性が必要な場合は、各データ値に UTF-8 プレフィックスを追加してください。以下も参照してください。

于 2013-04-24T22:20:02.633 に答える
2
 <a id="export" role='button'>
        Click Here To Download Below Report
    </a>
    <table id="testbed_results" style="table-layout:fixed">
        <thead>
            <tr width="100%" style="color:white" bgcolor="#3195A9" id="tblHeader">
                <th>Name</th>
                <th>Date</th>
                <th>Speed</th>
                <th>Column2</th>
                <th>Interface</th>
                <th>Interface2</th>
                <th>Sub</th>
                <th>COmpany result</th>
                <th>company2</th>
                <th>Gen</th>
            </tr>
        </thead>
        <tbody>
            <tr id="samplerow">
                <td>hello</td>
                <td>100</td>
                <td>200</td>
                <td>300</td>
                <td>html2svc</td>
                <td>ajax</td>
                <td>200</td>
                <td>7</td>
                <td>8</td>
                <td>9</td>
            </tr>
            <tr>
                <td>hello</td>
                <td>100</td>
                <td>200</td>
                <td>300</td>
                <td>html2svc</td>
                <td>ajax</td>
                <td>200</td>
                <td>7</td>
                <td>8</td>
                <td>9</td>
            </tr>
        </tbody>
    </table>

    $(document).ready(function () {
        Html2CSV('testbed_results', 'myfilename','export');
    });



    function Html2CSV(tableId, filename,alinkButtonId) {
        var array = [];
        var headers = [];
        var arrayItem = [];
        var csvData = new Array();
        $('#' + tableId + ' th').each(function (index, item) {
            headers[index] = '"' + $(item).html() + '"';
        });
        csvData.push(headers);
        $('#' + tableId + ' tr').has('td').each(function () {

            $('td', $(this)).each(function (index, item) {
                arrayItem[index] = '"' + $(item).html() + '"';
            });
            array.push(arrayItem);
            csvData.push(arrayItem);
        });




        var fileName = filename + '.csv';
        var buffer = csvData.join("\n");
        var blob = new Blob([buffer], {
            "type": "text/csv;charset=utf8;"
        });
        var link = document.getElementById(alinkButton);

        if (link.download !== undefined) { // feature detection
            // Browsers that support HTML5 download attribute
            link.setAttribute("href", window.URL.createObjectURL(blob));
            link.setAttribute("download", fileName);
        }
        else if (navigator.msSaveBlob) { // IE 10+
            link.setAttribute("href", "#");
            link.addEventListener("click", function (event) {
                navigator.msSaveBlob(blob, fileName);
            }, false);
        }
        else {
            // it needs to implement server side export
            link.setAttribute("href", "http://www.example.com/export");
        }
    }

</script>
于 2015-10-13T16:51:16.420 に答える
2

@Terry Youngの回答の小さな更新、つまり IE 10+ のサポートの追加

if (window.navigator.msSaveOrOpenBlob) {
  // IE 10+
  var blob = new Blob([decodeURIComponent(encodeURI(csvString))], {
    type: 'text/csv;charset=' + document.characterSet
  });
  window.navigator.msSaveBlob(blob, filename);
} else {
  // actual real browsers
  //Data URI
  csvData = 'data:application/csv;charset=utf-8,' + encodeURIComponent(csvData);

    $(this).attr({
      'download': filename,
      'href': csvData,
      'target': '_blank'
    });
}
于 2015-11-24T11:41:11.963 に答える
1

CSV 形式のデータを HTML に変換して Web ページに表示するとどうなるでしょうか。http://code.google.com/p/js-tables/プラグインを使用できます。この例を確認してください http://code.google.com/p/js-tables/wiki/Table すでに jQuery ライブラリを使用しているため、他の JavaScript ツールキット ライブラリを追加できると想定しています。

データが CSV 形式の場合、汎用の「application/octetstream」MIME タイプを使用できるはずです。試した 3 つの MIME タイプはすべて、クライアント コンピュータにインストールされているソフトウェアに依存しています。

于 2013-04-23T14:14:05.733 に答える
1

私が理解していることから、テーブルにデータがあり、そのデータから CSV を作成したいと考えています。ただし、CSV の作成に問題があります。

私の考えは、テーブルの内容を反復して解析し、解析されたデータから文字列を生成することです。例として、JSON を CSV 形式に変換して変数に格納する方法を確認できます。あなたの例では jQuery を使用しているため、外部プラグインとしてカウントされません。次に、結果の文字列をwindow.open使用application/octetstreamして、提案どおりに使用するだけです。

于 2013-04-24T03:15:21.843 に答える