0

このスクリプトを変更しようとしています: https://github.com/ariya/phantomjs/blob/master/examples/render_multi_url.js「rendermulti-1.png (など)」の代わりに出力ファイルがそれらがキャップである Web ページにちなんで名付けられます。

これが私が試したものです。

    // Render Multiple URLs to file

var RenderUrlsToFile, arrayOfUrls, system;

system = require("system");

/*
Render given urls
@param array of URLs to render
@param callbackPerUrl Function called after finishing each URL, including the last URL
@param callbackFinal Function called after finishing everything 
*/
RenderUrlsToFile = function(urls, callbackPerUrl, callbackFinal) {
    var getFilename, next, page, retrieve, urlIndex, webpage, pagename ; //<--
    urlIndex = 0;
    webpage = require("webpage");
    page = null;
    // replace forward slashes with underscores          //<--
    pagename = arrayOfUrls[urlIndex].replace(/\//g,'_'); //<--
    getFilename = function() {
    //  return "rendermulti-" + urlIndex + ".png";       //<--
        return pagename + ".png";                        //<--
    };
    next = function(status, url, file) {
        page.close();
        callbackPerUrl(status, url, file);
        return retrieve();
    };
    retrieve = function() {
        var url;
        if (urls.length > 0) {
            url = urls.shift();
            urlIndex++;
            page = webpage.create();
            page.viewportSize = {
                width: 800,
                height: 600
            };
            page.settings.userAgent = "Phantom.js bot";
            return page.open("http://" + url, function(status) {
                var file;
                file = getFilename();
                if (status === "success") {
                    return window.setTimeout((function() {
                        page.render(file);
                        return next(status, url, file);
                    }), 200);
                } else {
                    return next(status, url, file);
                }
            });
        } else {
            return callbackFinal();
        }
    };
    return retrieve();
};

arrayOfUrls = null;

if (system.args.length > 1) {
    arrayOfUrls = Array.prototype.slice.call(system.args, 1);
} else {
    console.log("Usage: phantomjs render_multi_url.js [domain.name1, domain.name2, ...]");
    arrayOfUrls = ["www.google.com", "www.bbc.co.uk", "www.phantomjs.org"];
}

RenderUrlsToFile(arrayOfUrls, (function(status, url, file) {
    if (status !== "success") {
        return console.log("Unable to render '" + url + "'");
    } else {
        return console.log("Rendered '" + url + "' at '" + file + "'");
    }
}), function() {
    return phantom.exit();
});

スクリプトは実行されますが、最初に指定された URL の後にすべてのファイルの名前が付けられ、「/」以降はすべて無視されます。

おそらくスコープに関係する基本的なエラーを起こしていると思いますが、新しい変数を getFileName 関数に移動すると、問題が発生します。

どんな助けでも大歓迎です。

ありがとう!

4

2 に答える 2

0

はい、このメソッドを変更するだけでよいと思います

getFilename = function() {
    return "rendermulti-" + urlIndex + ".png";       //<--
    return pagename + ".png";                        //<--
};

出力ファイル名を指定します。

PS。この js に 90 個の html ファイルをレンダリングするように指定した場合、ほとんどの場合、すべてのファイルをレンダリングできませんでした。これらの 90 個のファイルすべてを完了するには、何度も実行する必要があります。

そして、htmlファイルを小さな配列に分割してから、このjsを呼び出してレンダリングしようとしましたが、このjsファイルにはexitメソッドがあり、プロセスを終了します。そのため、これらの小さな html ファイルの URL 配列をすべてループして 1 回で終了することはできませんでした。

于 2015-12-11T04:24:13.063 に答える