生成html提交到git仓库

基于目前的express博客,写了一点代码,通过request模块来请求站点,将html保存到coding-pages目录,复制静态文件夹到coding-pages,最后使用node的child_process模块执行cmd命令提交到仓库~~

  1. 发送http请求

var request = require('request');
var options = {
url: url,
encoding: null,
headers: { 'User-Agent': 'Mozilla/5.0 (Macintosh;
Intel Mac OS X 10_10_1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.65 Safari/537.36' }
};
request(options, function (error, response, body) {
//请求的回调,编码问题使用iconv模块解决
//var iconv = require('iconv-lite');
//var html=iconv.decode(body,'utf-8');
//若是需要解析html则可以使用cheerio模块
//var cheerio=require('cheerio').load(html,{decodeEntities: false});
//然后就可以像jqueryy一样去解析html了。
//cheerio('选择器');
});

然后就可以愉快的抓数据了。之前也写过基于request,iconv,cheerio,schedule(定时调度模块)写了一个抓取的框架

  1. 保存html到目录

得到url的路径部分(除去域名),即:/index.html,/msg.html...

现在只需要根据这个路径和获取到的html保存即可

此时有了保存的路径和内容,保存还不小事一桩么。如下。

    function writeText(pathName,content){
var dir= pathHelper.dirname(pathName);//获取到路径中的目录
fs.exists(dir, function (exists) {//如果不存在则创建目录
if(exists==false){
fs.mkdir(dir);
}
});
fs.writeFile(pathName, content, function (err) {//写入内容
if (err){
console.log(pathName+'生成失败');
}
});
}
  1. 使用node执行.bat文件复制静态文件到coding-pages目录

复制目录可以使用async模块实现的目录操作

调用copyDir方法即可。

也可以使用child_process模块来调用cmd命令实现

注:直接使用require('child_process').exec 执行xcopy并不能复制目录,需要一种折中的方式

如下:

var exec = require('child_process').exec;
var execbat = __dirname + '\\exec.bat';
//1. 创建复制脚本
commonHelper.writeText(execbat, 'xcopy F:\\CodingRepos\\yimocoding\\coding-pages\\tag F:\\CodingRepos\\yimocoding\\coding-pages\\tag3 /s /e /Q /Y /I');
//2.执行批处理复制目录
exec(execbat, function (err, stdout, stderr) {
if (err) {
console.log(err);
}
else{
console.log('复制成功');
}
});
//3.删除批处理文件
exec('del ' + execbat, function (err, stdout, stderr) {
if (err) {
console.log(err);
}else{
console.log('删除脚本成功');
}
})
  1. 啥?怎么提交到git

运行环境安装好。能从cmd命令提交(配置环境变量)

然后,看代码呗~~

var cmds = [
'git add *',
'git commit -m "提交。。。"',
'git push'
]
cmds.forEach(function (cmd, i) {
setTimeout(function () {
console.log(cmd);
exec(cmd, function (err, stdout, stderr) {
if (err) {
console.log(err);
}
});
}, i * 1000);
})

写文章还是挺累的。但是把用到的东西记录下来是有必要的。文笔欠佳,然记录一二也是挺好滴。

源码地址:https://coding.net/u/yimocoding/p/yimocoding/git/blob/coding-pages/index.js

使用node自动生成html并调用cmd命令提交代码到仓库的更多相关文章

  1. 根据wsdl文件,Java工程自动生成webservice客户端调用

    根据wsdl文件,Java工程自动生成webservice客户端调用 1,工具:带有webservice插件的myeclips 2,步骤: (1),新建一个Java工程:relationship (2 ...

  2. 根据wsdl文件,Web工程自动生成webservice客户端调用

    根据wsdl文件,Web工程自动生成webservice客户端调用 1,工具:带有webservice插件的eclips 2,步骤: (1),新建一个Web工程:WSDLTest (2),浏览器访问W ...

  3. myapp——自动生成小学四则运算题目的命令行程序(侯国鑫 谢嘉帆)

    1.Github项目地址 https://github.com/baiyexing/myapp.git 2.功能要求 题目:实现一个自动生成小学四则运算题目的命令行程序 功能(已全部实现) 使用 -n ...

  4. python调用cmd显示中文乱码及调用cmd命令

    os.system('dir') 解决方法加上 os.system('chcp 65001') ____________________________________________________ ...

  5. C语言调用Cmd命令以及执行系统软件

    C语言调用Cmd命令以及执行系统软件 http://blog.csdn.net/qq_16814591/article/details/43676377

  6. IE浏览器中使用js调用cmd命令行demo

    <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="C ...

  7. Python调用cmd命令

    常用的两种方式: 1.python的OS模块. OS模块调用CMD命令有两种方式:os.popen(),os.system(). 都是用当前进程来调用. os.system是无法获取返回值的.当运行结 ...

  8. eclipse根据.wsdl文件自动生成webservice的调用客户端

    1.工具:eclipse3.3或者是带有webservice插件的eclipse 2. 首先用浏览器访问webservice的站点,接着保存打开的页面,后缀为.wsdl. 3.把保存好的文件拷入ecl ...

  9. 使用Signature Tool自动生成P/Invoke调用Windows API的C#函数声明【转】

    原文链接:https://blog.csdn.net/Donjuan/article/details/3865026在网上看到很多网友在.NET程序中调用Win32 API,或者调用自己的VC DLL ...

随机推荐

  1. Sql 根据当前时间,获取星期一具体日期

    --根据当前时间,计算每周一日期,周日为每周第一天 declare @getDate datetime --set @getDate='2018-12-30' set @getDate='2019-0 ...

  2. HTML导出Excel文件(兼容IE及所有浏览器)

    注意:IE浏览器需要以下设置: 打开IE,在常用工具栏中选择“工具”--->Internet选项---->选择"安全"标签页--->选择"自定义级别&q ...

  3. 4.7做作业时发现,内联元素设置宽高背景以后正常不显示,但是设置了position:absolute;以后就可以显示了。起到了和display:block;一样的效果。然后查了一下知道了。

    如果内联元素定位属性设置为:absolate,元素脱离文档,即使a元素中没有内容,设置的背景依然会显示!

  4. centos7 安装mysql5.7.20(yum方式)

    windows下安装mysql请访问:windows下mysql5.7.20安装(zip包方式) 一.安装过程 1.安装wget yum install wget 2.查找yum源名称 在mysql官 ...

  5. ubuntu-14.04安装最新tensorflow记录

    1.安装英伟达驱动./NVIDIA-Linux-x86_64-384.69.runnvidia-smi成功表示驱动ok 2.安装cudadpkg -i cuda-repo-ubuntu1404-8-0 ...

  6. Numpy 创建数组

    ndarray 数组除了可以使用底层 ndarray 构造器来创建外, 也可以通过以下几种方式来创建. numpy.empty numpy.empty 方法用来创建一个指定形状(shape),数据类型 ...

  7. openstack 王者归来学习笔记

    rpc.call方法执行的流程:(下次看代码的时候可以根据这流程来看,注意:由于rpc服务器和客户端具有很松的耦合性,因此以上步骤并不是绝对的.) 1.rpc服务器定义和启动rpc服务 2.rpc服务 ...

  8. 最小化webpack项目

    先把代码贴出来,以后慢慢加说明 参考资料:入门 Webpack,看这篇就够了 / webpack 搭建自动打开,刷新浏览器 一.功能代码1.index.html <!DOCTYPE html&g ...

  9. flex布局嵌套之高度自适应

    查遍各大资源无任何flex嵌套布局的例子,经过自己折腾完成了项目中的高度自适应需求(更多应用于前端组件) 效果图: html代码:(关键地方已经用颜色特别标识 ^_^) <!DOCTYPE ht ...

  10. 笔记javascript

    // var demo1=12;// alert('点击确定按钮看结果'+demo1);// for(var i = 0; i<10;i++)// {//     document.write( ...