//注意:要将PHPWord\PHPWord\Template.php中的setValue方法下的编码改成$replace = iconv('gbk', 'utf-8',$replace);其他的文件也要改成这种样式的。否则出现中文乱码。
require_once '../libs/PHPWord/PHPWord.php';
require_once '../libs/PHPWord/PHPWord/IOFactory.php';
require_once '../../config.php';
// require_once '../common/conn.php';
// New Word Document
$PHPWord = new PHPWord();
/**********文本格式的word text.php************/
// New portrait section
//逗号 分割字符串
$arr = $_REQUEST['arr'];
$a = explode(',',$arr);
//echo $arr;
date_default_timezone_set("Asia/Shanghai");//设置一个时区
$tm=date('Y-m-d H:i:s');
//exit($tm);
/**********前多日雨量*********/
if(in_array('1', $a, TRUE)){
$section = $PHPWord->createSection();
$PHPWord->addFontStyle('rStyle', array('bold'=>false, 'italic'=>false, 'size'=>16));
$PHPWord->addParagraphStyle('pStyle', array('align'=>'center', 'spaceAfter'=>100));
$c = "前三日雨量报表";
$section->addText($c, 'rStyle', 'pStyle');
$styleTable = array('borderSize'=>6, 'borderColor'=>'006699', 'cellMargin'=>80);
$styleFirstRow = array('borderBottomSize'=>18, 'borderBottomColor'=>'0000FF', 'bgColor'=>'66BBFF');
// Define cell style arrays
$styleCell = array('valign'=>'center');
// Define font style for first row
$fontStyle = array('bold'=>true, 'align'=>'center');
//设置标题
$PHPWord->addFontStyle('rStyle', array('bold'=>true, 'italic'=>true, 'size'=>16));
$PHPWord->addParagraphStyle('pStyle', array('align'=>'center', 'spaceAfter'=>100));
// Add table style
$PHPWord->addTableStyle('myOwnTableStyle', $styleTable, $styleFirstRow);
// Add table
$table = $section->addTable('myOwnTableStyle');
// Add row设置行高
$table->addRow(500);
$table->addCell(2300, $styleCell)->addText('站码', $fontStyle);
$table->addCell(2300, $styleCell)->addText('站名', $fontStyle);
$table->addCell(2300, $styleCell)->addText('雨量', $fontStyle);
$table->addCell(2300, $styleCell)->addText('水文站监测类型', $fontStyle);
$conn = mssql_connect($config['mssql']['host'],$config['mssql']['user'],$config['mssql']['password']);
mssql_select_db($config['mssql']['dbname'],$conn);
$stm = date('Y-m-d H:i:s',strtotime('-3 days'));
$sql = "EXEC HNOW05_GETPPSPACE '','','".$stm."',1,1";
$res=mssql_query($sql);
while($arr = mssql_fetch_array($res)){
//echo $arr["STCD"]."
";
$table->addRow();
$table->addCell(2300)->addText($arr["STCD"]);
$table->addCell(2300)->addText($arr["STNM"]);
$table->addCell(2300)->addText($arr["P"]);
if($arr["STTP"] == 'MM'){
$table->addCell(2300)->addText('气象站');
}else if($arr["STTP"] == 'BB'){
$table->addCell(2300)->addText('蒸发站');
}else if($arr["STTP"] == 'DD'){
$table->addCell(2300)->addText('堰闸水文站');
}else if($arr["STTP"] == 'TT'){
$table->addCell(2300)->addText('落潮位站');
}else if($arr["STTP"] == 'DP'){
$table->addCell(2300)->addText('泵站');
}else if($arr["STTP"] == 'SS'){
$table->addCell(2300)->addText('墒情站');
}else if($arr["STTP"] == 'PP'){
$table->addCell(2300)->addText('雨量站');
}else if($arr["STTP"] == 'ZZ'){
$table->addCell(2300)->addText('河道水位水文站');
}else if($arr["STTP"] == 'RR'){
$table->addCell(2300)->addText('水库水文站');
}else if($arr["STTP"] == 'ZG'){
$table->addCell(2300)->addText('地下水站');
}else if($arr["STTP"] == 'ZB'){
$table->addCell(2300)->addText('分洪水位站');
}
}
$section->addTextBreak(2);
}else{
}
/******地质灾害*******/
if(in_array('3', $a, TRUE)){
$section = $PHPWord->createSection();
$PHPWord->addFontStyle('rStyle', array('bold'=>false, 'italic'=>false, 'size'=>16));
$PHPWord->addParagraphStyle('pStyle', array('align'=>'center', 'spaceAfter'=>100));
$c = "地质灾害";
$section->addText($c, 'rStyle', 'pStyle');
$content="根据市气象局未来24小时降雨预报和市水利局实时降雨数据,市国土资源局进行了地质灾害预报,请有关部门关注
实时预警信息,做好地质灾害防范工作";
$section->addText($content);
// Add image elements
$section->addImage("images/image001.jpg", array('width'=>600, 'height'=>480, 'align'=>'center'));
}else{
}
// Save File
$fileName = "word报表".date("YmdHis");
header("Content-type: application/vnd.ms-word");
header("Content-Disposition:attachment;filename=".$fileName.".docx");
header('Cache-Control: max-age=0');
$objWriter = PHPWord_IOFactory::createWriter($PHPWord, 'Word2007');
$objWriter->save('php://output');
在WORD文档中,如何用两个符号SYMBOL字符190来替换字符串**
这题还是用“替换”,只不过在替换时当你输入完“替换为”的内容以后,你要点击左下方的“高级”按钮,再点击“格式”按钮,然后选中“字体”,把字体选定为问题中要求的Symbol和Wingdings字体。注意:格式中字体设置分为“中文字体”和“西文字体”,Symbol字符190和Wingdings字符74是在“西文字体”中设定的。
怎样在word中将字符串转换成表格
Word2007中把要放入不同单元格的文字用空格隔开,换行时按回车键不要按空格就,排列好填入表格的各行内容,选中文字——插入——表格——文本转换成表格——弹出“将文字转换成表格”——修改列数——确定。
我用c#怎么获取word文档中一个table下面的一行字符串,这个字符串在table下面,紧挨着table
先定位table位置,再用选取方法处理,很长时间没有做了代码工作了,table很好定位,可以写个循环,如果下面的代码忘,可以用word中的自定义宏查看相应的与代码再一致到c#中
我要获取的数据不在table表格里,在table表格的外面,我能获取table里面的数据,但是我不知道怎么获取table的位置,word里获取位置不是一般用Paragraphs吗,我不知道怎么获取到这个Paragraphs值
asp.net 以流的方式将html 形式的多个Table字符串 写入word中怎样换页呢? 急!!! 请教高手解答
你应该写如txt中,或者写入数据库,写入word会有冗余代码的。
你说的换页是什么意思?换页一般是自动换的,不用你在设置什么。
打字不容易,感觉ok就给个好评采纳吧,谢谢。。。。。
我是要生成报表的直接把table 生成到word里了就是想让每个table在单独页中,单不知道怎么换页
何必这么麻烦,把每个表写进数据库。
要显示调出来直接生成html就可以了。
也可以分页显示。
如何在php中不使用系统函数来实现分割字符串
1查找字符位置函数: strpos($str,search,[int]):查找search在$str中的第一次位置从int开始; stripos($str,search,[int]):函数返回字符串在另一个字符串中第一次出现的位置。该函数对大小写不敏感 strrpos($str,search,[int]):查找search在$str中的最后一次出现的位置从int 2、提取子字符函数(双字节) submit($str,int start[,int length]):从$str中strat位置开始提取[length长度的字符串]。 strstr($str1,$str2):从$str1(第一个的位置)搜索$str2并从它开始截取到结束字符串;若没有则返回FALSE。 stristr() 功能同strstr,只是不区分大小写。 strrchr() 从最后一次搜索到的字符处返回;用处:取路径中文件名 3、替换字符串 str_replace(search,replace,$str):从$str中查找search用replace来替换 str_irreplace(search,replace,$str): strtr($str,search,replace):这个函数中replace不能为""; substr_replace($Str,$rep,$start[,length])$str原始字符串,$rep替换后的新 字符串,$start起始位置,$length替换的长度,该项可选 4、字符长度 int strlen($str) 5、比较字符函数 int strcmp($str1,$str2):$str1>=<$str2分别为正1,0,-1(字符串比较) strcasecmp() 同上(不分大小写) strnatcmp("4","14") 按自然排序比较字符串 strnatcasecmp() 同上,(区分大小写) 6、分割成数组函数 str_split($str,len):把$str按len长度进行分割返回数组 split(search,$str[,int]):把$str按search字符进行分割返回数组int是分割几次,后面的将不分割 expload(search,$str[,int]) 7、去除空格:ltrim、rtrim、trim 8、加空格函数 chunk_split($str,2);向$str字符里面按2个字符就加入一个空格; 9、chr、ord--返回指定的字符或ascii 10、HTML代码有关函数 nl2br():使\n转换为<br>。 strip_tags($str[,'<p>']):去除HTML和PHP标记 在$str中所有HTML和PHP代码将被去除,可选参数为html和PHP代码作用是将保留 可选参数所写的代码。 如:echo strip_tags($text, '<br><p>'); htmlspecialchars($str[,参数]):页面正常输出HTML代码参数是转换方式 11、字符大小写转换函数 strtolower($str) 字符串转换为小写 strtoupper($str) 字符串转换为大写 ucfirst($str) 将函数的第一个字符转换为大写 ucwords($str) 将每个单词的首字母转换为大写 12、数据库相关函数 addslashes($str):使str内单引号(')、双引号(")、反斜线(\)与 NUL 字符串转换为\',\",\\。 magic_quotes_gpc = On 自动对 get post cookie的内容进行转义 get_magic_quotes_gpc()检测是否打开magic_quotes_gpc stripslashes() 去除字符串中的反斜杠 13、连接函数 implode(str,$arr) 将字符串数组按指定字符连接成一个字符串;implode()函数有个别名函数join addcslashes —— 为字符串里面的部分字符添加反斜线转义字符 addslashes —— 用指定的方式对字符串里面的字符进行转义 bin2hex —— 将二进制数据转换成十六进制表示 chr —— 返回一个字符的ASCII码 chunk_split —— 按一定的字符长度将字符串分割成小块 convert_cyr_string —— 将斯拉夫语字符转换为别的字符 convert_uudecode —— 解密一个字符串 convert_uuencode —— 加密一个字符串 count_chars —— 返回一个字符串里面的字符使用信息 crc32 —— 计算一个字符串的crc32多项式 crypt —— 单向散列加密函数 explode —— 将一个字符串用分割符转变为一数组形式 fprintf —— 按照要求对数据进行返回,并直接写入文档流 get_html_translation_table —— 返回可以转换的HTML实体 html_entity_decode —— htmlentities ()函数的反函数,将HTML实体转换为字符 htmlentities —— 将字符串中一些字符转换为HTML实体 htmlspecialchars_decode —— htmlspecialchars()函数的反函数,将HTML实体转换为字符 htmlspecialchars —— 将字符串中一些字符转换为HTML实体 implode —— 将数组用特定的分割符转变为字符串 join —— 将数组转变为字符串,implode()函数的别名 levenshtein —— 计算两个词的差别大小 localeconv —— 获取数字相关的格式定义 ltrim —— 去除字符串左侧的空白或者指定的字符 md5_file —— 将一个文件进行MD5算法加密 md5 —— 将一个字符串进行MD5算法加密 metaphone —— 判断一个字符串的发音规则 money_format —— 按照参数对数字进行格式化的输出 nl_langinfo —— 查询语言和本地信息 nl2br —— 将字符串中的换行符“\n”替换成“<br />” number_format —— 按照参数对数字进行格式化的输出 ord —— 将一个ASCII码转换为一个字符 parse_str —— 把一定格式的字符串转变为变量和值 print —— 用以输出一个单独的值 printf —— 按照要求对数据进行显示 quoted_printable_decode —— 将一个字符串加密为一个8位的二进制字符串 quotemeta —— 对若干个特定字符进行转义 rtrim —— 去除字符串右侧的空白或者指定的字符 setlocale —— 设置关于数字,日期等等的本地格式 sha1_file —— 将一个文件进行SHA1算法加密 sha1 —— 将一个字符串进行SHA1算法加密 similar_text —— 比较两个字符串,返回系统认为的相似字符个数 soundex —— 判断一个字符串的发音规则 sprintf —— 按照要求对数据进行返回,但是不输出 sscanf —— 可以对字符串进行格式化 str_ireplace —— 像str_replace()函数一样匹配和替换字符串,但是不区分大小写 str_pad —— 对字符串进行两侧的补白 str_repeat —— 对字符串进行重复组合 str_replace —— 匹配和替换字符串 str_rot13 —— 将字符串进行ROT13加密处理 str_shuffle —— 对一个字符串里面的字符进行随机排序 str_split —— 将一个字符串按照字符间距分割为一个数组 str_word_count —— 获取字符串里面的英文单词信息 strcasecmp —— 对字符串进行大小比较,不区分大小写 strchr —— 通过比较返回一个字符串的部分strstr()函数的别名 strcmp —— 对字符串进行大小比较 strcoll – 根据本地设置对字符串进行大小比较 strcspn —— 返回字符连续非匹配长度的值 strip_tags —— 去除一个字符串里面的HTML和PHP代码 stripcslashes —— 反转义addcslashes()函数转义处理过的字符串 stripos —— 查找并返回首个匹配项的位置,匹配不区分大小写 stripslashes —— 反转义addslashes()函数转义处理过的字符串 stristr —— 通过比较返回一个字符串的部分,比较时不区分大小写 strlen —— 获取一个字符串的编码长度 strnatcasecmp —— 使用自然排序法对字符串进行大小比较,不区分大小写 strnatcmp —— 使用自然排序法对字符串进行大小比较 strncasecmp —— 对字符串的前N个字符进行大小比较,不区分大小写 strncmp —— 对字符串的前N个字符进行大小比较 strpbrk —— 通过比较返回一个字符串的部分 strpos —— 查找并返回首个匹配项的位置 strrchr —— 通过从后往前比较返回一个字符串的部分 strrev —— 将字符串里面的所有字母反向排列 strripos —— 从后往前查找并返回首个匹配项的位置,匹配不区分大小写 strrpos —— 从后往前查找并返回首个匹配项的位置 strspn —— 匹配并返回字符连续出现长度的值 strstr —— 通过比较返回一个字符串的部分 strtok —— 用指定的若干个字符来分割字符串 strtolower —— 将字符串转变为小写 strtoupper —— 将字符串转变为大写 strtr —— 对字符串比较替换 substr_compare —— 对字符串进行截取后的比较 substr_count —— 计算字符串中某字符段的出现次数 substr_replace —— 对字符串中的部分字符进行替换 substr —— 对字符串进行截取 trim —— 去除字符串两边的空白或者指定的字符 ucfirst —— 将所给字符串的第一个字母转换为大写 ucwords —— 将所给字符串的每一个英文单词的第一个字母变成大写 vfprintf —— 按照要求对数据进行返回,并直接写入文档流 vprintf —— 按照要求对数据进行显示 vsprintf —— 按照要求对数据进行返回,但是不输出 wordwrap —— 按照一定的字符长度分割字符串 1,快速创建数组的函数range() 比如range()函数可以快速创建从1到9的数字数组: <?php $numbers=range(1,9); //用range直接创建1~9共9个数字组成的数组,以“1”开始“9”结束。 echo $numbers[1]; //输出创建的第二个数组值:2; echo $numbers[0];则输入第一个值:0。 ?> 当然,使用range(9,1)则创建了9到1的数字数组。同时,range()还可以创建从a到z 的字符数组: <?php $numbers=range(a,z); foreach ($numbers as $mychrs) //遍历$numbers数组,每次循环当前单元值被赋给$mychrs echo $mychrs." "; //output a b c d e f g h i j k l m n o p q r s t u v w x y z ?> //foreach是一种遍历数组的简便方法,foreach 仅能用于数组,当试图将其用于其它数据类型或者一个未初始化的变量时会产生错误,它有两种格式: foreach (array_expression as $value) statementforeach (array_expression as $key => $value) statement 第一种格式遍历给定的 array_expression 数组。每次循环中,当前单元的值被赋给 $value 并且数组内部的指针向前移一步(因此下一次循环中将会得到下一个单元)。第二种格式做同样的事,只除了当前单元的键名也会在每次循环中被赋给变量 $key 使用字符数组时注意大小写,比如range(A,z)和range(a,Z)是不一样的。 range()函数还具有第三个参数,该参数的作用是设定步长,比如range(1,9,3)创建的数组元素是:1、4、7 2,PHP中常规数组的排序 一般数组中的各元素均以字符或数字表现的,所以可对数组元素进行升序排列,该功能函数为sort()。比如: <?php $people=array('name','sex','nation','birth'); foreach ($people as $mychrs) echo $mychrs." "; sort($people); echo "<br />---排序后---<br />"; foreach ($people as $mychrs) echo $mychrs." "; ?> 升序排序后的数组元素显示为 birth name nation sex,当然,sort()函数是区分字母大小写的(字母从大到小的顺序是:A…Z…a…z) Sort()函数还具有第二参数,用来说明升序的规则是用来比较数字还是字符串的。比如: <?php echo "---按数字升序排序---<br />"; $num2=array('26','3',); sort($num2,SORT_NUMERIC); foreach ($num2 as $mychrs) echo $mychrs." "; echo "<br />---按字符升序排序---<br />"; $num3=array('26','3'); sort($num3,SORT_STRING); foreach ($num3 as $mychrs) echo $mychrs." "; ?> SORT_NUMERIC和SORT_STRING用来声明按数字或字符的升序排列。如果按照数字升序排列是:3,26;但如果按照字符升序排列则是:26,3了。 PHP中除了升序函数以外,还有降序或称反向排列的函数,就是rsort()函数,比如: $num1=range(1,9); rsort($num1); //这里其实就相当于range(9,1) 3,PHP中关联数组的排序 PHP除了支持数字索引数组以外,还支持相关数组。比如如下数组就是一个相关(关联)数组: $peoples=array('xm'=>'name','xb'=>'sex','mz'=>'nation','cs'=>'birth'); 使用sort($peoples)默认即是按照元素定义值的升序排序,在关联数组中可使用asort()函数表示按元素值升序排序,关联数组中最主要的则是可按照关键字(如xm、xb、mz等)的升序排序,该方法是用函数ksort()函数。 <?php $peoples=array('xm'=>'name','xb'=>'sex','mz'=>'nation','cs'=>'birth'); foreach ($peoples as $mychrs) echo $mychrs." "; echo "<br />--按元素值升序排列--<br />"; asort($peoples); foreach ($peoples as $mychrs) echo $mychrs." "; echo "<br />--按关键字升序排列--<br />"; ksort($peoples); foreach ($peoples as $mychrs) echo $mychrs." "; ?> 和常规数组拥有sort()升序函数的反向排序rsort()降序函数相对应的,关联数组也有对应的降序函数:asort()函数和arsort()函数、ksort()函数和krsort()函数。 记忆:原型函数是sort(),其中a、k表示关联数组相关必须前置,反向排序使用r修饰。 4,PHP数组元素随机排序 PHP中使用shuffle()函数将数组元素进行随机的重新排序,每次都会显示不同的排序组合,比如: <?php $fer=array('cnbruce','cnrose','cnjames','cnanne'); shuffle($fer); //随即排序,每刷新一次页面则进行一次随机排序。 foreach ($fer as $mychrs) echo $mychrs." "; ?> 5,PHP数组按原顺序反向排序 PHP中可使用array_reverse()函数将数组元素按原顺序反向排序。比如: <?php $fer=array('cnbruce','cnrose','cnjames','cnanne'); foreach ($fer as $mychrs) echo $mychrs." "; $fer=array_reverse($fer); //将数组内元素按原顺序反向排序 echo "<br />--按原顺序反向--<br />"; foreach ($fer as $mychrs) echo $mychrs." "; ?> output: cnbruce cnrose cnjames cnanne --按原顺序反向-- cnanne cnjames cnrose cnbruce 注意这里的 $fer=array_reverse($fer); 在此之前的任何排序函数均只是声明引用,并没有对原有数组进行重新定义,但当我调试该函数时则需要重新定义。这是因为array_reverse()是返 回原数组修改后的副本,如果不需要原有数组,可对原数组重新定义达到覆盖的目的,否则就另外定义数组保存副本,比 如:$fer_bak=array_reverse($fer_bak);
能否用简便的语句来描述下思路和实现过程,你这代码复制过来太乱了
在Word文档中用两个紧挨着的符号Symbol字符190来替换字符串“**”。应该如何操作?替换后是什么样子的?
是否要将SYMBOL字体的190替换为××,其它字符190不换!
如是,要设置替换高级选项,输入190,在下面 高级 格式 字体 内找到SYMBOL。然后替换为输入××
转载请注明出处51数据库 » php字符串转wordtable php怎样转换成word
不吃鱼的丶喵

