这里有关于excel文件的几个概念需要跟大家说明一下,这几个概念对于我们的后续编程是很有帮助的:
1.工作簿:在excel环境中用来存储数据并处理数据的文件,又称为excel文件或excel文档,
    在一个工作簿中,可以拥有多张不同类型的工作表,无论有多少张工作表,在将其保存时,都将会保存在一个工作簿文件中,而不是按照工作表的个数来保存的
    在默认情况下,每一个工作簿文件会包含三个工作表文件:sheet1,sheet2,sheet3

2.工作表:是由多行和多列所构成的一个二维表格,行号的编号是自上而下从1开始,列号则从左到右采用字母编号,从A开始

3.单元格:行坐标和列坐标做指定的位置,称为单元格,列名和行号做组成的名称为单元格名称

大家好,利用这个时间,带领大家学习excel报表技术在企业项目中的使用。

在网站的管理后台经常会使用到报表的生成和读取,其中Excel是最为常见的报表格式之一,今天我们就来学习在php中的如何操作Excel报表。

在正式学习之前,我们先来演示一下excel报表技术在真实项目中的使用案例?
案例1:excel报表技术在电子税务系统中的使用
        ①统计纳税人每一项税务的纳税情况:城市维护建设税,企业所得税等

在php中生成excel报表文件,主要是通过header()向浏览器发送头信息来完成的

php生成Excel报表文件的方式有如下几种:

好,现在我们就通过php程序来生成一个简单excel文件

案例:

<?php
//首先,在php文件的开头,通过header()定义输出的文件类型为excel文件
//定义输出的文件类型,表示输出的是一个excel文件
header("Content-type:application/vnd.ms-excel");
//定义输出的文件名,表示输出的文件名为test.xls,如果文件名为中文,用iconv函数进行转码
header("Content-Disposition:filename=test.xls");

//为什么要加\t和\n呢?主要是通过程序的手段来模拟table键和回车键
echo "test1\t";        //  \t:table键 ,通过程序的手段来模拟table键和回车键的按下
echo "test2\t\n";    //    \t\n:table键并换行

echo "test1\t";
echo "test2\t\n";

echo "test1\t";
echo "test2\t\n";

echo "test1\t";
echo "test2\t\n";

echo "test1\t";
echo "test2\t\n";

echo "test1\t";
echo "test2\t\n";

//其实在大部分情况下,可以将数据从数据库中取出,然后按照每一列数据结束后加\t,每一行数据结束后加\n的方法echo出来

//给excel表格的每一列添加一个标题
echo "ID\t";
echo "客户简称\t";
echo "客户全名\t";
echo "联系人\t";
echo "联系电话\t";
echo "传真\t";
echo "地址\t\n";

mysql_connect("localhost","root","");
mysql_select_db("jxc2008");
mysql_query("set names 'utf8'");
$sql="select * from kehu order by id desc";
$rec=mysql_query($sql);//返回一个结果集
$row_num=mysql_num_rows($rec);//结果集中的行数
$col_num=mysql_num_fields($rec);//结果集中的列数

while($row=mysql_fetch_array($rec)){//从结果集中逐行获取记录
    for($col=0;$col<$col_num;$col++){
        if($col==($col_num-1)){//excel文件中列的数字编号从0开始,总列数-1 对应excel文件中最大列的编号
            echo $row[$col]."\t\n";//如果是最后一列,加上 \n 来模拟回车键
        }else{
            echo $row[$col]."\t";//每一行数据逐列输出到excel文件单元格中,不是最后一列时,加上 \t 来模拟tab键
        }
    }
}
?>
通过运行如下程序,就生成了一个简单的excel文件。通过这种方式来生成excel文件呢,有他的优点,也有他的缺点:
优点:上面这种格式,相对比较简单,因为比较单一
缺点:对于控制生成的excel表格样式很不方便,读取excel文件和不方便

案例:通过<table>表格的方式来生成一个excel文件:省略

缺点:更复杂点的报表就要麻烦点了,要在模板中一个个单元格自己去放置 StyleID 值

问题:虽然使用php的header()可以直接生成excel,但是对于控制生成的excel样式(如:居中对齐,背影颜色等)是很不方便的,所以这里推荐一个最为流行的Excel类库-PHPExcel

PHPExcel类库是一个非常强大的php类库,基本上能解决一切的excel问题,企业中对excel报表的处理大多是采用此类库来完成的

此类库可到其官网 http://www.codeplex.com/PHPExcel 去下载,目前最新版本为1.7.7,我这里已经将其下载下来了,

将其解压到我的web应用中,解压后发现里面有三个文件夹:
    classess:此文件夹中是PHPExcel核心类库文件,我们对excel报表的处理都是通过此文件夹中的类文件来完成的,注意:所有的类名都是以PHPExcel_*开头的
        特点:所有的文件都是一个类
              所有的类名都是以PHPExcel_*开头
    Documentation:这个文件夹中存放的是PHPExcel类库的英文说明文档
    Tests:是一些小的测试案例,这些小案例对于我们入门是非常有帮助的

首先,我们打开一个测试文件来快速体验一把。执行测试文件后。会提示我们进行下载

这里有关于excel文档的两个概念需要跟大家解释一下:
    工作簿:包含多个工作表的excel文档,也就是说,工作簿==excel文档,我们所建立的excel文档的名称就是工作簿的名称
    工作表:有行有列的二维表,多个工作表组成了一个工作簿

好,知道了这些呢,我们就来解读一下这个php测试文件

PHPExcel实现了autoloader自动加载机制,这意味着我们不需要引入PHPExcel文件夹下的每个类库文件,只需要在文件中引入PHPExcel初始化类库文件就可以了,自动加载类,将自动引入其它需要的类库文件

为了简化PHPExcel类的概念,PHPExcel类代表你的工作簿

对于常见的excel报表操作,我们需要掌握如下几个类库就可以了:
1.工作簿对象类:PHPExcel
    2.工作表对象类:PHPExcel_WorkSheet
        3.样式对象类:PHPExcel_Style
            4.对齐方式对象类:PHPExcel_Style_Alignment
            5.字体对象类:PHPExcel_Style_Font
                6.颜色对象类:PHPExcel_Style_Color
        7.单元格类:PHPExcel_Cell
8.读写文件的类:PHPExcel_IOFactory
    9.读文件的类:PHPExcel_Reader_Excel5
    10.写文件的类:PHPExcel_Writer_Excel5

大家可以看的出来,我写的有一定的层级关系,为什么这么写呢?是因为在很多情况下低层级的类依赖于其上一层级的类

对于常见的excel报表操作,我们需要掌握如下几个类库就可以了:

(1)PHPExcel:工作簿对象

excel文档处理对象主要用来管理我们的excel文档,怎么来管理(通过属性和方法来管理)?大家知道,类主要是由属性和方法来组成,通过php程序的手段来管理excel文档,其实就是通过本对象的属性和方法来管理,下面我们就来看一下PHPExcel类中都有那些属性和方法,这些属性和方法主要用来管理excel文档的那些方面
    
    getProperties():获得当前活动状态工作表的属性对象,返回属性对象
    getActiveSheet():获得当前活动状态的工作表,返回工作表对象
    getActiveSheetIndex():获得当前活动状态工作表的索引值,返回int
    setActiveSheetIndex():设置当前活动状态工作表的索引,返回工作表对象
    getSheetByName():通过工作表名称得到当前工作表对象,返回工作表对象
    getDefaultStyle():获得excel文档默认的样式(所有工作表的样式),返回样式对象
    createSheet():在当前活动工作表后创建一个新的工作表
    getSheetCount():获得excel文档中工作表的数量,返回int
    getSheetNames():获得excel文档中所有工作表名称组成的数组
    
(2)PHPExcel_Worksheet:工作表对象

工作表对象,主要用来管理我们的工作表,怎么管理?也是通过属性和方法来管理,但是工作表对象大部分情况下可通过excel文档对象来获取

toArray():把工作表中的数据转换成数组
    fromArray():从数组中获取数据填充到工作表,返回工作表对象
    getCell():获得单元格对象
    getCellByColumnAndRow():通过列索引和行索引获得指定单元格,返回单元格对象
    getDefaultStyle():获得工作表默认的样式,返回样式对象
    getHighestColumn():获得工作表的最大列,返回列的名称
    getColumnDimension():获得当前列
    getStyle():获得指定单元格的样式,返回样式对象
    getParent():获得父类对象,返回excel文档对象
    getTitle():获得工作表的标题或名称,返回字符串类型
    setCellValue():设置单元格的值,返回工作表对象或单元格对象,完全取决于参数的值
    setCellValueByColumnAndRow():通过列索引和行索引设置单元格的值,返回类型同上
    setCellValueExplicit():设置单元格的值,并显示指定数据类型,返回工作表对象
    setCellValueExplicitByColumnAndRow():通过列和行索引设置单元格值
    setTitle():设置工作表标题

(3)PHPExcel_Cell:单元格对象
        
(3)PHPExcel_Style:样式对象,主要用来设置单元格的样式:对齐方式、字体、边框、填充等,跟我们之前学过的css样式差不多,在这里如果想要设置对齐方式、字体大小、边框颜色、等等都是通过样式对象来完成的
    
    getActiveCell():获得当前活动的单元格的名称,返回string;如,A1
    getActiveSheet():获得当前活动的工作表,返回工作表对象
    getAlignment():获得对齐方式对象,返回对齐方式对象
    getBorders():获得边框对象,返回边框对象
    getFill():获得填充对象
    getFont():获得字体对象
    setFont():设置字体,返回样式对象

(3)PHPExcel_Style_Alignment:对齐方式对象

getHorizontal():获得水平居中方式
    getVertical():获得垂直居中方式
    setHorizontal():设置水平居中方式,返回对齐方式对象
    setVertical():设置垂直居中方式,返回对齐方式对象

居中方式:
        HORIZONTAL_CENTER 
        HORIZONTAL_CENTER_CONTINUOUS
        HORIZONTAL_GENERAL 
        HORIZONTAL_JUSTIFY 
        HORIZONTAL_LEFT 
        HORIZONTAL_RIGHT 
        VERTICAL_BOTTOM 
        VERTICAL_CENTER 
        VERTICAL_JUSTIFY 
        VERTICAL_TOP

(3)PHPExcel_Style_Font:字体对象

setBold():设置字体加粗
    setColor():设置字体颜色
    setItalic():设置字体倾斜
    setName():设置字体名
    setSize():设置字体大小
    setUnderline():设置字体下划线

(4)PHPExcel_Writer_Excel5:写操作对象,主要用来输出xls文件

save(工作簿文件名):将工作簿对象中的数据保存到一个工作簿文件中

(4)PHPExcel_Writer_Excel2007:写操作对象,主要用于输出xlsx文件

save(工作簿文件名):将工作簿对象中的数据保存到一个工作簿文件中

(5)PHPExcel_Reader_Excel5:读操作对象,主要用于输入xls文件
    
    canRead():当前reader对象是否能够读工作簿文件
    load():从一个工作簿文件中加载工作簿对象,也就是将工作簿文件中的数据加载到工作簿对象中来管理

(6)PHPExcel_IOFactory:读写操作对象

createReader():根据参数的不同,创建不同的读对象:主要作用是读取工作簿文件中的数据

createWriter():根据参数的不同,返回不同的写对象:主要作用是将PHPExcel工作簿对象中的数据写入到一个工作簿文件中

load():从工作簿文件中加载PHPExcel工作簿对象,即:将工作簿文件中数据加载到PHPExcel工作簿对象中来管理

PHPExcel对象:是一个工作簿对象

include_once "PHPExcel/Writer/Excel5.php";//主要用于其它低版本,且文件名后缀为xls的文件,如果我们希望生成后缀名为xls格式的excel文件,建议引入此类库

include_once "PHPExcel/Writer/Excel2007.php";//主要用于excel2007格式,文件名后缀为xlsx的excel文件,如果我们希望生成后缀名为xlsx格式的excel文件,建议引入此类库

$objWriter = new PHPExcel_Writer_Excel5($objExcel);//创建一个文件格式写入对象实例,此对象主要用来写入内容到指定格式的文件,如,写入内容到后缀名为xls格式的excel文件等,用于其它板式的格式

$objWriter = new PHPExcel_Writer_Excel2007($objExcel);//创建一个文件格式写入对象实例,此对象主要用来写入内容到指定格式的文件,如,写入内容到后缀名为xls格式的excel文件等,用于excel2007格式
$objWriter->setOffice2003Compatibility(true);//兼容office2003

//设置文档基本属性  
$objProps = $objExcel->getProperties();  //得到PHPExcel_document文档对象
$objProps->setCreator("Zeal Li");       //设置作者
$objProps->setLastModifiedBy("Zeal Li"); //设置最后修改时间
$objProps->setTitle("Office XLS Test Document"); //设置标题
$objProps->setSubject("Office XLS Test Document, Demo");//设置主题
$objProps->setDescription("Test document, generated by PHPExcel.");//描 
$objProps->setKeywords("office excel PHPExcel"); //关键字
$objProps->setCategory("Test"); //分类

$objExcel->setActiveSheetIndex(0);//设置用户打开excel文件时,看到的首张sheet,如果没有设置,默认为最后一次操作的sheet

$objActSheet->setTitle('测试Sheet');//设置当前活动的工作簿名称

//根据单元格名称设置单元格内容,由PHPExcel根据传入的内容自动判断单元格的内容类型 
$objActSheet->setCellValue('A1', '字符串内容');  // 字符串内容 
$objActSheet->setCellValue('A2', 26);            // 数值 
$objActSheet->setCellValue('A3', true);          // 布尔值 
$objActSheet->setCellValue('A4', '=SUM(A2:A2)'); // 公式

/显式指定单元格的内容类型为字符串类型  
$objActSheet->setCellValueExplicit('A5','847475847857487584',PHPExcel_Cell_DataType::TYPE_STRING);

//合并单元格  
$objActSheet->mergeCells('B1:C22');

//设置列的宽度  
$objActSheet->getColumnDimension('B')->setAutoSize(true);
$objActSheet->getColumnDimension('A')->setWidth(30);

//设置行的高度
$objPHPExcel->getActiveSheet()->getRowDimension('2')->setRowHeight(11.5);

//格式:主要用来对单元格进行操作,如,设置字体、设置对齐方式、设置边框等
$objStyleA5 = $objActSheet->getStyle('A5');//获取A5单元格的样式

//设置单元格的字体
$objFontA5 = $objStyleA5->getFont(); //获得字体
$objFontA5->setName('宋体');//设置字体名称 
$objFontA5->setSize(10);  //设置字体大小
$objFontA5->setBold(true);//设置字体加粗
$objFontA5->getColor()->setARGB('FF999999');//设置字体颜色

//设置单元格的对齐方式  
$objAlignA5 = $objStyleA5->getAlignment();//获得对齐方式
$objAlignA5->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);//水平居右 
$objAlignA5->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);//垂直居中

//设置单元格的边框  
$objBorderA5 = $objStyleA5->getBorders();//获取边框 
$objBorderA5->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//边框样式
$objBorderA5->getTop()->getColor()->setARGB('FFFF0000');//顶部边框的颜色 
$objBorderA5->getBottom()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN); 
$objBorderA5->getLeft()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//左样式
$objBorderA5->getRight()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);//右样式

//设置单元格的填充色
$objFillA5 = $objStyleA5->getFill();//填充 
$objFillA5->setFillType(PHPExcel_Style_Fill::FILL_SOLID);//填充类型 
$objFillA5->getStartColor()->setARGB('FFEEEEEE');

//计算单元格的值
$objPHPExcel->getActiveSheet()->setCellValue('B7', '=SUM(B5:C5)');
$objPHPExcel->getActiveSheet()->getCell('B7')->getCalculatedValue();
//如果要获取单元格的一个值,首先需要通过工作表的getCell方法获取到一个单元格对象,然后再通过单元格对象的getValue方法得到单元格的值,如果单元格的值是通过计算得到的,则需要使用getCalculatedValue方法获取单元格的值,设置单元格的值,我们只需要通过工作表的setCellValue方法来设置即可

//$dateTimeNow=time();
$objPHPExcel->getActiveSheet()->setCellValue('C10', PHPExcel_Shared_Date::PHPToExcel( $dateTimeNow ));//41105.75

$objPHPExcel->getActiveSheet()->getStyle('C10')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_DATE_TIME4);//18:00:54,只是换了一种显示方式,并不会改变原来值的类型

echo gettype($objPHPExcel->getActiveSheet()->getCell('C10')->getValue());//double
echo $objPHPExcel->getActiveSheet()->getCell('C10')->getValue();//41105.75

//'2010-10-21'一定要放在引号中,否则显示的值为,1979               文本(推荐)
$objPHPExcel->setActiveSheetIndex(0)->setCellValueExplicit("D1", '2010-10-21', PHPExcel_Cell_DataType::TYPE_STRING); //特征:字符串类型都是居左显示

//添加一个新的worksheet  
$objExcel->createSheet();//创建一个新的工作表
$objExcel->getSheet(1)->setTitle('测试2');//设置当前工作表的标题

//保护单元格  
$objExcel->getSheet(1)->getProtection()->setSheet(true); 
$objExcel->getSheet(1)->protectCells('A1:C22', 'PHPExcel');

//输出内容到excel文件,并将文件保存在服务器上
$objWriter->save("test.xls");

//强制输出内容到浏览器下载  
header("Content-Type: application/force-download"); 
header("Content-Type: application/octet-stream"); 
header("Content-Type: application/download"); 
header('Content-Disposition:inline;filename="'.$outputFileName.'"'); 
header("Content-Transfer-Encoding: binary"); 
header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); 
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); 
header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); 
header("Pragma: no-cache");  
$objWriter->save('php://output');//参数-表示直接输出到浏览器,供客户端下载

//excel读取对象
$PHPReader = new PHPExcel_Reader_Excel5();//创建一个excel文件的读取对象
$PHPExcel = $PHPReader->load($filePath);//读取一张excel表,返回excel文件对象
$currentSheet = $PHPExcel->getSheet(0);//读取excel文件中的第一张工作表
$allColumn = $currentSheet->getHighestColumn();//取得当前工作表最大的列号,如,E
$allRow = $currentSheet->getHighestRow();//取得当前工作表一共有多少行

//设置工作簿默认的样式
$objPHPExcel->getDefaultStyle()->getFont()->setName('Arial');
$objPHPExcel->getDefaultStyle()->getFont()->setSize(8);

//合并单元格
$objPHPExcel->getActiveSheet()->mergeCells('A18:E22');

案例1:使用迭代器循环所有的单元格;读取工作表中所有单元格的值,显示到一个table表格中

<?php 
        $objReader = PHPExcel_IOFactory::createReader('Excel2007');
        $objReader->setReadDataOnly(true);
        $objPHPExcel = $objReader->load("test.xlsx");
        $objWorksheet = $objPHPExcel->getActiveSheet();//获取当前活动工作表
        echo '<table>' . "\n"; 
        foreach ($objWorksheet->getRowIterator() as $row) {
          echo '<tr>' . "\n";   
          $cellIterator = $row->getCellIterator();
          $cellIterator->setIterateOnlyExistingCells(false);
          foreach ($cellIterator as $cell) {
            echo '<td>' . $cell->getValue() . '</td>' . "\n";
          } 
          echo '</tr>' . "\n"; 
        } 
        echo '</table>' . "\n"; 
    ?>

案例2:使用索引循环所有单元格

<?php 
        $objReader = PHPExcel_IOFactory::createReader('Excel2007');
        $objReader->setReadDataOnly(true);  
        $objPHPExcel = $objReader->load("test.xlsx");
        $objWorksheet = $objPHPExcel->getActiveSheet();
        $highestRow = $objWorksheet->getHighestRow(); // e.g. 10
        $highestColumn = $objWorksheet->getHighestColumn(); // e.g 'F'
        $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn); // 5
        echo '<table>'."\n"; 
        for ($row = 1; $row <= $highestRow; ++$row) {
          echo '<tr>' . "\n"; 
          for ($col = 0; $col <= $highestColumnIndex; ++$col) {
            echo '<td>' . $objWorksheet->getCellByColumnAndRow($col, $row)->getValue().'</td>'."\n";
          } 
          echo '</tr>'."\n"; 
        } 
        echo '</table>'."\n"; 
    ?>

【php】对PHPExcel一些简单的理解的更多相关文章

  1. 简单的理解deflate算法

    简单的理解deflate算法 最近做压缩算法. 用到了deflate压缩算法,  找了很多资料,  这篇文章算是讲的比较易懂的, 这篇文章不长,但却浅显易懂, 基本上涵盖了我想要知道的所有要点. 翻译 ...

  2. OSI七层模式简单通俗理解

    OSI七层模式简单通俗理解 这个模型学了好多次,总是记不住.今天又看了一遍,发现用历史推演的角度去看问题会更有逻辑,更好记.本文不一定严谨,可能有错漏,主要是抛砖引玉,帮助记性不好的人.总体来说,OS ...

  3. 对js原型简单的理解和图解

    对js原型简单的理解和图解 最近在努力的学习js中,今天就抽了个空把自己理解的原型,记下一下在笔记中,以后自己查看,有空在会把原型链记录一下. 1.prototype prototype:是一个函数的 ...

  4. 最简单的理解 建立TCP连接 三次握手协议

     最简单的理解一:建立TCP连接:三次握手协议    客户端:我要对你讲话,你能听到吗:服务端:我能听到:而且我也要对你讲话,你能听到吗:客户端:我也能听到.…….互相开始通话…….. 二:关闭TCP ...

  5. 微信小程序简单入门理解

    简单的小程序示例结构: (一):理解小程序结构app.js,app.json,app.wxss ①app.js,app.json是小程序结构必要的部分,app.wxss可选择 ②app.js用于创建小 ...

  6. MyBatis源码解析【8】简单demo理解接口式编程

    前言 这个分类比较连续,如果这里看不懂,或者第一次看,请回顾之前的博客 http://www.cnblogs.com/linkstar/category/1027239.html 上一次我们经过源码的 ...

  7. DDos与CC攻击的简单个人理解

    DDos简单来说就是向指定IP发送大量无用的数据包,造成网卡堵塞. CC理解成模拟表单提交,真实模拟业务,但量大之后也会造成网络堵塞. 参考: http://www.enkj.com/idcnews/ ...

  8. 如何简单的理解TDD与DDT

    TDD:TEST-DRIVEN Development 测试驱动开发究竟是什么意思?如何理解测试驱动开发? 举个红绿条简单的例子: 1.编写测试代码 2.编译运行测试代码,肯定会失败,因为实现代码还没 ...

  9. DRP-ThreadLocal简单的理解

      简单就是jar一类套餐包.在一个简单的事情是一个工具类!该工具可以做?该工具被用来写多线程程序,行.多线程是有效的.你只能去网上找资料,由于今天我们仅仅来介绍ThreadLocal的知识. 我们来 ...

随机推荐

  1. SMB/CIFS协议解析一概述

    一.SMB/CIFS协议的区别 在NetBIOS出现之后,Microsoft就使用NetBIOS实现了一个网络文件/打印服务系统,这个系统基于NetBIOS设定了一套文件共享协 议,Microsoft ...

  2. KnockoutJS(1)-数据模型

    前言 说到数据模型(ViewModel),就不得不提到MVVM模式,接触过WPF和Silverlight的人应该对这个模式比较熟悉. 不熟悉也没多大关系,因为KnockoutJS的使用相对简单. MV ...

  3. Android:ListView之ViewHolder

    前言 在开发Android应用过程中经常要与列表展示打交道,比如Listview.在使用过程中如果不能正确的进行细节处理那么对性能还是有很大的损耗的. Listview展示内容是通过一个Adapter ...

  4. jquery.prompt.js 弹窗的使用

    /*** * Prompt提示语插件 * 编写时间:2013年4月8号 * version:Prompt.1.0.js * author:小宇<i@windyland.com> ***/ ...

  5. 另一个 SqlParameterCollection 中已包含 SqlParameter

    出处:http://www.cnblogs.com/OldYongs/archive/2011/03/12/1982021.html#2742742 一般情况下,我们定义的一个SqlParameter ...

  6. centos6.5安装配置LDAP服务[转]

    安装之前查一下 1 find / -name openldap* centos6.4默认安装了LDAP,但没有装ldap-server和ldap-client 于是yum安装 1 su root 2 ...

  7. SPOJ 4487 Splay 基本操作

    插入操作,删除操作和置换操作都是单点的,所以不需要lazy标记.这个很简单,都是两次RotateTo,一次Splay操作就搞定. 求最大连续字段和的操作和线段树的题目类似,只需要保存最左边的连续最大字 ...

  8. 微软职位内部推荐-Principal DEV Manager for Bing Client

    微软近期Open的职位: Title: Principal DEV Manager for Bing ClientGroup: Search Technology Center Asia, BingW ...

  9. 获取不变的UDID-b

    iOS唯一标识的历史历程 iOS 6.0 在iOS6.0以前,是使用uniqueIdentifier来获取手机的唯一标识,后来苹果感觉这样会泄露用户隐藏,就封掉了这个方法: iOS 6.0系统新增了两 ...

  10. 实时数据处理环境搭建flume+kafka+storm:4.storm安装配置

    1.解压 apache-storm-0.9.3.tar.gz   2.修改配置文件 conf/storm.yaml --zk地址  storm.zookeeper.servers:  - " ...