c#操作word文档之简历导出
前言
1、写这个功能之前,我得说说微软的这个类库,用着真苦逼!是他让我有程序猿,攻城尸的感觉了。首先这个类库,从没接触过,方法与属性都不懂,还没有提示。神啊,我做这功能真是一步一卡,很潇洒啊。
2、这个功能做下来了,不过通过苦逼的摸索我找到了一个捷径,就是 word 自带的 宏 ,感谢 word , 感谢宏 , 是它让我看到了,成功的可能性。
3、
说说宏,对于word来说,宏就是建立word文档的命令集,不过对于c#程序员来说,宏使用的是神器 vb
编写的。看到这里不懂神器的你,是不是顿悟了想死的心。呵呵,不用,因为,通过看宏的编码,我们可以感受到c#的影子,有些属性名字,很庆幸,在c#中是
不变的。
看看宏代码
使用宏,是录制宏,然后查看宏,就行了,下面我展示一个建立表格的宏命令
Sub 宏3()
'
' 宏3 宏
'
'
ActiveDocument.Tables.Add Range:=Selection.Range, NumRows:=8, NumColumns:= _
7, DefaultTableBehavior:=wdWord9TableBehavior, AutoFitBehavior:= _
wdAutoFitFixed
With Selection.Tables(1)
If .Style <> "网格型" Then
.Style = "网格型"
End If
.ApplyStyleHeadingRows = True
.ApplyStyleLastRow = False
.ApplyStyleFirstColumn = True
.ApplyStyleLastColumn = False
.ApplyStyleRowBands = True
.ApplyStyleColumnBands = False //上面代码是在word中简历一个 8行 7列的表格
End With
Selection.MoveDown Unit:=wdLine, Count:=8 //向下移动八个光标,跳出表格
Selection.TypeParagraph //等于点回车键
Selection.TypeText Text:="上面有段向下移动光标的代码,因为不移动光标,怎么会有这一行字呢"
End Sub
上面这段代码,现在也许看着对我们的帮助不大,但是,一旦我们通过c#简历word 文档的时候,我们无从下手, 不知属性 ,方法的时候,就可以参照上面的代码,来写我们自己的代码了。
看看c#代码
这个功能真的没什么好说的,看代码说事吧。
引用 com ---》 Microsoft.Office.Interop.Word
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.IO;
using Microsoft.Office.Interop.Word;
using com.enkj.job.WebUI.App_Code;
using System.Data;
using System.Reflection;
using JobCommon;
namespace com.enkj.job.WebUI.HttpHandler
{
/// <summary>
/// LoadWordResume 的摘要说明
/// </summary>
public class LoadWordResume : PersonUserBase,IHttpHandler
{
public DataSet ds = null;
public List<Model.Person> perList = null;
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
if (context.Request["action"] != null && context.Request["action"].ToString() == "LoadResume")
{
GetDataSet();
context.Response.Write(CreateWord());
context.Response.End();
}
}
DataSet GetDataSet()
{
ds = new Module.PersonResume().GetResumeInfo(sessionID, ResumeId);
if (ds != null)
{
return ds;
}
throw new NoNullAllowedException();
}
public string CreateWord()
{
string message = "";
try
{
Object Nothing = System.Reflection.Missing.Value;
Directory.CreateDirectory("D:/JobResume"); //创建文件所在目录
string name = "JobResume_" + DateTime.Now.ToString("yyyyMMddhhmmssfff") + ".doc";//文件名
object filename = "D://JobResume//" + name; //文件保存路径
//创建Word文档
Microsoft.Office.Interop.Word.Application WordApp = new Microsoft.Office.Interop.Word.ApplicationClass();
Microsoft.Office.Interop.Word.Document WordDoc = WordApp.Documents.Add(ref Nothing, ref Nothing, ref Nothing, ref Nothing);
WordApp.Selection.PageSetup.LeftMargin = 85f;
WordApp.Selection.PageSetup.RightMargin = 85f;
WordApp.Selection.PageSetup.PageWidth = 650f; //页面宽度
//添加页眉
WordApp.ActiveWindow.View.Type = WdViewType.wdOutlineView;
WordApp.ActiveWindow.View.SeekView = WdSeekView.wdSeekPrimaryHeader;
WordApp.ActiveWindow.ActivePane.Selection.InsertAfter("蓝领招聘网模板生成");
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphRight;//设置右对齐
WordApp.ActiveWindow.View.SeekView = WdSeekView.wdSeekMainDocument;//跳出页眉设置
WordApp.Selection.ParagraphFormat.LineSpacing = 15f;//设置文档的行间距
//移动焦点并换行
object count = 14;
object WdLine = Microsoft.Office.Interop.Word.WdUnits.wdLine;//换一行;
WordApp.Selection.Text = "个人简历";
WordApp.Selection.ParagraphFormat.LineSpacing = 30f;
WordApp.Selection.Range.Bold = 2;
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
WordApp.Selection.MoveDown(ref WdLine, ref count, ref Nothing);//移动焦点
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
WordApp.Selection.TypeParagraph();//插入段落
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;
WordApp.Selection.ParagraphFormat.LineSpacing = 16;
WordApp.Selection.Font.Size = 10f;
WordApp.Selection.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorGray40;
//文档中创建表格
Microsoft.Office.Interop.Word.Table newTable = WordDoc.Tables.Add(WordApp.Selection.Range,8, 3, ref Nothing, ref Nothing);
//设置表格样式
newTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleNone;
newTable.Columns[1].Width = 175f;
newTable.Columns[2].Width = 170f;
newTable.Columns[3].Width = 135f;
//填充表格内容
newTable.Cell(1, 1).Range.Text = "个人信息";
newTable.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体
newTable.Cell(1, 1).Range.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
//合并单元格
newTable.Cell(1, 1).Merge(newTable.Cell(1, 3));
WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalBottom;//垂直居下
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;//水平居左
WordApp.Selection.Shading.BackgroundPatternColorIndex = Microsoft.Office.Interop.Word.WdColorIndex.wdGray25;
newTable.Rows[1].Range.ParagraphFormat.LineSpacing = 20f;
//填充表格内容
newTable.Cell(2, 1).Range.Text = "姓名:"+ds.Tables[0].Rows[0]["name"];
newTable.Cell(2, 2).Range.Text = "性别:" + Common.DoEnum.EnumManager<JobCommon.ApplicationEnum.Sex>.GetEnumDesc(JobTool.Toint(ds.Tables[0].Rows[0]["sex"]));
//纵向合并单元格
newTable.Cell(2, 3).Select();//选中一行
object moveUnit = Microsoft.Office.Interop.Word.WdUnits.wdLine;
object moveCount = 5;
object moveExtend = Microsoft.Office.Interop.Word.WdMovementType.wdExtend;
WordApp.Selection.MoveDown(ref moveUnit, ref moveCount, ref moveExtend);
WordApp.Selection.Cells.Merge();
//插入图片
string FileName = Server.MapPath(ds.Tables[0].Rows[0]["Photo"]!=null&&ds.Tables[0].Rows[0]["Photo"].ToString().Length>0?ds.Tables[0].Rows[0]["Photo"].ToString():"/sys_admin/images/noImg.jpg");//图片所在路径
object LinkToFile = false;
object SaveWithDocument = true;
object Anchor = WordDoc.Application.Selection.Range;
WordDoc.Application.ActiveDocument.InlineShapes.AddPicture(FileName, ref LinkToFile, ref SaveWithDocument, ref Anchor);
WordDoc.Application.ActiveDocument.InlineShapes[1].Width = 80f;//图片宽度
WordDoc.Application.ActiveDocument.InlineShapes[1].Height = 100f;//图片高
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
//将图片设置为四周环绕型
Microsoft.Office.Interop.Word.Shape s = WordDoc.Application.ActiveDocument.InlineShapes[1].ConvertToShape();
s.WrapFormat.Type = Microsoft.Office.Interop.Word.WdWrapType.wdWrapSquare;
newTable.Cell(3, 1).Range.Text = "出生日期: "+Convert.ToDateTime(ds.Tables[0].Rows[0]["birthday"]).ToString("yyyy年MM月dd日");
newTable.Cell(3, 2).Range.Text = "居住地 :" + GetCity();
newTable.Cell(4, 1).Range.Text = "工作年限: " + GetWorkYears();
newTable.Cell(5, 1).Range.Text = ds.Tables[0].Rows[0]["MobileNumber"] == null ? "手机号码: "+ds.Tables[0].Rows[0]["MobileNumber"] : "联系电话: "+ds.Tables[0].Rows[0]["PhoneNumber"];
newTable.Cell(6, 1).Range.Text = "邮编:" + ds.Tables[0].Rows[0]["PostCode"] == null ? "稍后填写" : ds.Tables[0].Rows[0]["PostCode"].ToString();
newTable.Cell(6, 1).Range.Text = "身高:" + ds.Tables[0].Rows[0]["Height"] +" cm";
newTable.Cell(7, 1).Range.Text = "户口 :" + GetHomeCity();
newTable.Cell(8, 1).Range.Text = "QQ :" + (ds.Tables[0].Rows[0]["QQ"] == null ? "稍后填写" : ds.Tables[0].Rows[0]["QQ"].ToString());
newTable.Cell(8,1).Range.Text = "电子邮箱:" + (ds.Tables[0].Rows[0]["Email"] == null ? "稍后填写" : ds.Tables[0].Rows[0]["Email"].ToString());
//求职意向
object missing = System.Reflection.Missing.Value;
object count2 = 2;
object WdLine2 = Microsoft.Office.Interop.Word.WdUnits.wdLine;//换一行;
WordApp.Selection.MoveDown(ref WdLine2, ref count2, ref missing);//光标向下移1行
WordApp.Selection.TypeParagraph();//在表格外回车
if (ds.Tables[1].Rows.Count > 0)
{
//文档中创建表格
Microsoft.Office.Interop.Word.Table QzyxTable = WordDoc.Tables.Add(WordApp.Selection.Range, 6, 1, ref Nothing, ref Nothing);
//设置表格样式
QzyxTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleNone;
QzyxTable.Columns[1].Width = 480f;
//填充表格内容
QzyxTable.Cell(1, 1).Range.Text = "求职意向";
QzyxTable.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体
QzyxTable.Cell(1, 1).Range.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
//合并单元格
WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalBottom;//垂直居下
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;//水平居左
WordApp.Selection.Shading.BackgroundPatternColorIndex = Microsoft.Office.Interop.Word.WdColorIndex.wdGray25;
QzyxTable.Rows[1].Range.ParagraphFormat.LineSpacing = 20f;
QzyxTable.Cell(2, 1).Range.Text = "工作性质: " + GetJobType();
QzyxTable.Cell(3, 1).Range.Text = "期望月薪: " + GetMouthSalary();
QzyxTable.Cell(4, 1).Range.Text = "工作地点: " + ds.Tables[1].Rows[0]["Workplace"];
QzyxTable.Cell(5, 1).Range.Text = "到岗时间: " + ds.Tables[1].Rows[0]["WorkTime"];
QzyxTable.Cell(6, 1).Range.Text = "自我评价: " + ds.Tables[1].Rows[0]["MyEvaluate"];
}
//工作经验
object count3 = 6;
WordApp.Selection.MoveDown(ref WdLine2, ref count3, ref missing);//光标向下移1行
WordApp.Selection.TypeParagraph();//在表格外回车
int j = 2;
if (ds.Tables[3].Rows.Count > 0)
{
//工作经验个数
int i = ds.Tables[3].Rows.Count;
//文档中创建表格
Microsoft.Office.Interop.Word.Table GzjyTable = WordDoc.Tables.Add(WordApp.Selection.Range, i*5, 1, ref Nothing, ref Nothing);
//设置表格样式
GzjyTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleNone;
GzjyTable.Columns[1].Width = 480f;
//填充表格内容
GzjyTable.Cell(1, 1).Range.Text = "工作经验";
GzjyTable.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体
GzjyTable.Cell(1, 1).Range.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
//合并单元格
WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalBottom;//垂直居下
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;//水平居左
WordApp.Selection.Shading.BackgroundPatternColorIndex = Microsoft.Office.Interop.Word.WdColorIndex.wdGray25;
GzjyTable.Rows[1].Range.ParagraphFormat.LineSpacing = 20f;
for (int k = 0; k < i; k++)
{
GzjyTable.Cell(j, 1).Range.Text = JobTool.ToDateTimeNow(ds.Tables[3].Rows[k]["BeginTime"]).ToString("yyyy-MM") + "--" + JobTool.ToDateTimeNow(ds.Tables[3].Rows[k]["EndTime"]).ToString("yyyy-MM") + ":" + " " + ds.Tables[3].Rows[k]["WorkCompany"] + "(" + GetComRange(ds.Tables[3].Rows[k]["Scale"]) + ")" + " [ " + GetInWorkYears(ds.Tables[3].Rows[k]["BeginTime"], ds.Tables[3].Rows[k]["EndTime"]) + "]";
GzjyTable.Cell(j + 1, 1).Range.Text = "所属行业: " + GetIndustryType(ds.Tables[3].Rows[k]["Industry"]);
GzjyTable.Cell(j + 2, 1).Range.Text = ds.Tables[3].Rows[k]["Department"] + " " + ds.Tables[3].Rows[k]["Post"];
GzjyTable.Cell(j + 3, 1).Range.Text = "" + ds.Tables[3].Rows[k]["WorkDescription"];
if (i * 5 + 1 != j + 4)
{
GzjyTable.Cell(j + 4, 1).Range.InlineShapes.AddHorizontalLineStandard(ref Nothing);
}
j = j + 5;
}
}
//教育经历
object count4 = j;
WordApp.Selection.MoveDown(ref WdLine2, ref count4, ref missing);//光标向下移1行
WordApp.Selection.TypeParagraph();//在表格外回车
if (ds.Tables[2].Rows.Count > 0)
{
//教育经历个数
int i = ds.Tables[2].Rows.Count;
//文档中创建表格
Microsoft.Office.Interop.Word.Table jyjlTable = WordDoc.Tables.Add(WordApp.Selection.Range, i * 4, 1, ref Nothing, ref Nothing);
//设置表格样式
jyjlTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleNone;
jyjlTable.Columns[1].Width = 480f;
//填充表格内容
jyjlTable.Cell(1, 1).Range.Text = "教育经历";
jyjlTable.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体
jyjlTable.Cell(1, 1).Range.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
//合并单元格
WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalBottom;//垂直居下
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;//水平居左
WordApp.Selection.Shading.BackgroundPatternColorIndex = Microsoft.Office.Interop.Word.WdColorIndex.wdGray25;
jyjlTable.Rows[1].Range.ParagraphFormat.LineSpacing = 20f;
j = 2;
for (int k = 0; k < i; k++)
{
jyjlTable.Cell(j, 1).Range.Text = JobTool.ToDateTimeNow(ds.Tables[2].Rows[k]["BeginTime"]).ToString("yyyy-MM") + "--" + JobTool.ToDateTimeNow(ds.Tables[2].Rows[k]["EndTime"]).ToString("yyyy-MM") + ":" + " " + ds.Tables[2].Rows[k]["school"] + " (" + ds.Tables[2].Rows[k]["EduBackground"] + ")" ;
jyjlTable.Cell(j + 1, 1).Range.Text = "专业: " + ds.Tables[2].Rows[k]["Specialty"];
jyjlTable.Cell(j + 2, 1).Range.Text = ""+ds.Tables[2].Rows[k]["SpecialtyDescription"];
if (i * 4 + 1 != j + 3)
{
jyjlTable.Cell(j + 3, 1).Range.InlineShapes.AddHorizontalLineStandard(ref Nothing);
}
j = j + 4;
}
}
//培训经历
object count5 = j+8;
WordApp.Selection.MoveDown(ref WdLine2, ref count5, ref missing);//光标向下移1行
WordApp.Selection.TypeParagraph();//在表格外回车
if (ds.Tables[4].Rows.Count > 0)
{
//培训经历个数
int i = ds.Tables[4].Rows.Count;
//文档中创建表格
Microsoft.Office.Interop.Word.Table pxjlTable = WordDoc.Tables.Add(WordApp.Selection.Range, i * 5, 1, ref Nothing, ref Nothing);
//设置表格样式
pxjlTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleNone;
pxjlTable.Columns[1].Width = 480f;
//填充表格内容
pxjlTable.Cell(1, 1).Range.Text = "培训经历";
pxjlTable.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体
pxjlTable.Cell(1, 1).Range.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
//合并单元格
WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalBottom;//垂直居下
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;//水平居左
WordApp.Selection.Shading.BackgroundPatternColorIndex = Microsoft.Office.Interop.Word.WdColorIndex.wdGray25;
pxjlTable.Rows[1].Range.ParagraphFormat.LineSpacing = 20f;
j = 2;
for (int k = 0; k < i; k++)
{
pxjlTable.Cell(j, 1).Range.Text = "时 间: " + JobTool.ToDateTimeNow(ds.Tables[4].Rows[k]["BeginTime"]).ToString("yyyy-MM") + "--" + JobTool.ToDateTimeNow(ds.Tables[4].Rows[k]["EndTime"]).ToString("yyyy-MM") + "" + " 培训机构: " + ds.Tables[4].Rows[k]["CultivateCompany"] ;
pxjlTable.Cell(j + 1, 1).Range.Text = "培训地点: " + ds.Tables[4].Rows[k]["Address"] + " 培训课程: " + ds.Tables[4].Rows[k]["Subject"];
pxjlTable.Cell(j + 2, 1).Range.Text = "获得证书:" + ds.Tables[4].Rows[k]["Certificate"];
pxjlTable.Cell(j + 3, 1).Range.Text = "自我评价:" + ds.Tables[4].Rows[k]["Description"];
if (i * 5 + 1 != j + 4)
{
pxjlTable.Cell(j + 4, 1).Range.InlineShapes.AddHorizontalLineStandard(ref Nothing);
}
j = j + 5;
}
}
//语言能力
object count6 = j + 3;
WordApp.Selection.MoveDown(ref WdLine2, ref count6, ref missing);//光标向下移1行
WordApp.Selection.TypeParagraph();//在表格外回车
if (ds.Tables[5].Rows.Count > 0)
{
//语言能力个数
int i = ds.Tables[5].Rows.Count;
//文档中创建表格
Microsoft.Office.Interop.Word.Table yynlTable = WordDoc.Tables.Add(WordApp.Selection.Range, i * 5, 1, ref Nothing, ref Nothing);
//设置表格样式
yynlTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleNone;
yynlTable.Columns[1].Width = 480f;
//填充表格内容
yynlTable.Cell(1, 1).Range.Text = "语言能力";
yynlTable.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体
yynlTable.Cell(1, 1).Range.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
//合并单元格
WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalBottom;//垂直居下
WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;//水平居左
WordApp.Selection.Shading.BackgroundPatternColorIndex = Microsoft.Office.Interop.Word.WdColorIndex.wdGray25;
yynlTable.Rows[1].Range.ParagraphFormat.LineSpacing = 20f;
j = 2;
for (int k = 0; k < i; k++)
{
yynlTable.Cell(j, 1).Range.Text = "语言类别: " + ds.Tables[5].Rows[k]["language"];
yynlTable.Cell(j + 1, 1).Range.Text = "掌握程度:" + ds.Tables[5].Rows[k]["level"];
yynlTable.Cell(j + 2, 1).Range.Text = "读写能力:" + ds.Tables[5].Rows[k]["ReadWrite"];
yynlTable.Cell(j + 3, 1).Range.Text = "听说能力:" + ds.Tables[5].Rows[k]["ListenSpeak"];
if (i * 5 + 1 != j + 4)
{
yynlTable.Cell(j + 4, 1).Range.InlineShapes.AddHorizontalLineStandard(ref Nothing);
}
j = j + 5;
}
}
//文件保存
WordDoc.SaveAs(ref filename, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing);
WordDoc.Close(ref Nothing, ref Nothing, ref Nothing);
WordApp.Quit(ref Nothing, ref Nothing, ref Nothing);
message = name + "文档生成成功,以保存到 D:\\JobResume 下";
}
catch
{
message = "文件导出异常!";
}
return message;
}
public bool IsReusable
{
get
{
return false;
}
}
}
}
再看看效果吧,也算是我秀一下
转载原文:http://www.cnblogs.com/knowledgesea/archive/2013/05/24/3095376.html
最新文章
- connect 链接失败: 查找不到 signal
- 游戏笔记之《Fez》
- php基础教程-输出Hello World
- Windows Azure Web Site (17) Azure Web Site 固定公网IP地址
- coursera机器学习-支持向量机SVM
- 记一次使用命令行启动部署在tomcat上的应用
- Laravel Container分析
- Repost: Set Delivery Block on SO
- Android OkHttp详解
- css背景图与html插入img的区别
- Linq101-Conversion Operators
- js运算符单竖杠“|”的用法和作用及js数据处理
- iOS 私有API调用
- (转)批量插入sql语句
- GDB 命令回顾
- day93
- Drools(BRMS) 速成教程(上)
- Add-Migration : 无法将“Add-Migration”项识别为 cmdlet、函数、脚本文件或可运行程序的名称
- php- post表单 input name属性的问题
- 109. Magic of David Copperfield II 构造 难度:2
热门文章
- grep 基于关键字搜索
- 如何在Root的手机上开启ViewServer,使得HierachyViewer能够连接
- OpenStreetMap(OSM) features
- UVA 10003 Cutting Sticks 切木棍 dp
- php解决与处理网站高并发 大流量访问的方法
- ASP.NET repeater添加序号列的方法
- java中文乱码解决之道(二)—–字符编码详解:基础知识 + ASCII + GB**
- C# winfrom中Flash播放使用axShockwaveFlash控件设置透明XP出现白色背景解决办法,仿QQ魔法表情效果
- Ibatis代码自动生成工具——Abator安装与应用实例(图解)
- android webview点击返回键返回上一级activity