From 69c33979cacd1c50580428510e9d34163f9d9dc0 Mon Sep 17 00:00:00 2001 From: thinkgem Date: Sat, 6 Jan 2018 10:20:20 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B8=85=E7=90=86StringUtils=E7=94=A8=E8=BF=87?= =?UTF-8?q?=E6=B0=94=E7=9A=84=E6=96=B9=E6=B3=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../com/jeesite/common/lang/StringUtils.java | 934 ++++++++---------- 1 file changed, 411 insertions(+), 523 deletions(-) diff --git a/common/src/main/java/com/jeesite/common/lang/StringUtils.java b/common/src/main/java/com/jeesite/common/lang/StringUtils.java index ac0fe2f9..00ad4333 100644 --- a/common/src/main/java/com/jeesite/common/lang/StringUtils.java +++ b/common/src/main/java/com/jeesite/common/lang/StringUtils.java @@ -1,523 +1,411 @@ -/** - * Copyright (c) 2013-Now http://jeesite.com All rights reserved. - */ -package com.jeesite.common.lang; - -import java.io.UnsupportedEncodingException; -import java.util.List; -import java.util.Random; -import java.util.regex.Matcher; -import java.util.regex.Pattern; - -import org.apache.commons.lang3.StringEscapeUtils; - -import com.jeesite.common.codec.EncodeUtils; -import com.jeesite.common.collect.ListUtils; - -/** - * 字符串工具类, 继承org.apache.commons.lang3.StringUtils类 - * @author ThinkGem - * @version 2014-8-19 - */ -public class StringUtils extends org.apache.commons.lang3.StringUtils { - - private static final char SEPARATOR = '_'; - private static final String CHARSET_NAME = "UTF-8"; - - /** - * 转换为字节数组 - * @param str - * @return - */ - public static byte[] getBytes(String str){ - if (str != null){ - try { - return str.getBytes(CHARSET_NAME); - } catch (UnsupportedEncodingException e) { - return null; - } - }else{ - return null; - } - } - - /** - * 转换为字节数组 - * @param str - * @return - */ - public static String toString(byte[] bytes){ - try { - return new String(bytes, CHARSET_NAME); - } catch (UnsupportedEncodingException e) { - return EMPTY; - } - } - - /** - * 是否包含字符串 - * @param str 验证字符串 - * @param strs 字符串组 - * @return 包含返回true - */ - public static boolean inString(String str, String... strs){ - if (str != null && strs != null){ - for (String s : strs){ - if (str.equals(trim(s))){ - return true; - } - } - } - return false; - } - - /** - * 是否包含字符串 - * @param str 验证字符串 - * @param strs 字符串组 - * @return 包含返回true - */ - public static boolean inStringIgnoreCase(String str, String... strs){ - if (str != null && strs != null){ - for (String s : strs){ - if (str.equalsIgnoreCase(trim(s))){ - return true; - } - } - } - return false; - } - - /** - * 替换掉HTML标签方法 - */ - public static String stripHtml(String html) { - if (isBlank(html)){ - return ""; - } - //html.replaceAll("\\&[a-zA-Z]{0,9};", "").replaceAll("<[^>]*>", ""); - String regEx = "<.+?>"; - Pattern p = Pattern.compile(regEx); - Matcher m = p.matcher(html); - String s = m.replaceAll(""); - return s; - } - - /** - * 替换为手机识别的HTML,去掉样式及属性,保留回车。 - * @param html - * @return - */ - public static String toMobileHtml(String html){ - if (html == null){ - return ""; - } - return html.replaceAll("<([a-z]+?)\\s+?.*?>", "<$1>"); - } - - /** - * 对txt进行HTML编码,并将\n转换为>br/<、\t转换为    - * @param txt - * @return - */ - public static String toHtml(String txt){ - if (txt == null){ - return ""; - } - return replace(replace(EncodeUtils.escapeHtml(trim(txt)), "\n", "
"), "\t", "    "); - } - - /** - * 缩略字符串(不区分中英文字符) - * @param str 目标字符串 - * @param length 截取长度 - * @return - */ - public static String abbr(String str, int length) { - if (str == null) { - return ""; - } - try { - StringBuilder sb = new StringBuilder(); - int currentLength = 0; - for (char c : stripHtml(StringEscapeUtils.unescapeHtml4(str)).toCharArray()) { - currentLength += String.valueOf(c).getBytes("GBK").length; - if (currentLength <= length - 3) { - sb.append(c); - } else { - sb.append("..."); - break; - } - } - return sb.toString(); - } catch (UnsupportedEncodingException e) { - e.printStackTrace(); - } - return ""; - } - - // 缩略字符串替换Html正则表达式预编译 - private static Pattern p1 = Pattern.compile("<([a-zA-Z]+)[^<>]*>"); - - /** - * 缩略字符串(适应于与HTML标签的) - * @param param 目标字符串 - * @param length 截取长度 - * @return - */ - public static String htmlAbbr(String param, int length) { - if (param == null) { - return ""; - } - StringBuffer result = new StringBuffer(); - int n = 0; - char temp; - boolean isCode = false; // 是不是HTML代码 - boolean isHTML = false; // 是不是HTML特殊字符,如  - for (int i = 0; i < param.length(); i++) { - temp = param.charAt(i); - if (temp == '<') { - isCode = true; - } else if (temp == '&') { - isHTML = true; - } else if (temp == '>' && isCode) { - n = n - 1; - isCode = false; - } else if (temp == ';' && isHTML) { - isHTML = false; - } - try { - if (!isCode && !isHTML) { - n += String.valueOf(temp).getBytes("GBK").length; - } - } catch (UnsupportedEncodingException e) { - e.printStackTrace(); - } - - if (n <= length - 3) { - result.append(temp); - } else { - result.append("..."); - break; - } - } - // 取出截取字符串中的HTML标记 - String tempResult = result.toString().replaceAll("(>)[^<>]*(]*/?>", ""); - // 去掉成对的HTML标记 - tempResult = tempResult.replaceAll("<([a-zA-Z]+)[^<>]*>(.*?)", "$2"); - // 用正则表达式取出标记 - Matcher m = p1.matcher(tempResult); - List endHTML = ListUtils.newArrayList(); - while (m.find()) { - endHTML.add(m.group(1)); - } - // 补全不成对的HTML标记 - for (int i = endHTML.size() - 1; i >= 0; i--) { - result.append(""); - } - return result.toString(); - } - -// /** -// * 转换为Double类型 -// */ -// public static Double toDouble(final Object val){ -// return ObjectUtils.toDouble(val); -// } -// -// /** -// * 转换为Float类型 -// */ -// public static Float toFloat(final Object val){ -// return ObjectUtils.toFloat(val); -// } -// -// /** -// * 转换为Long类型 -// */ -// public static Long toLong(final Object val){ -// return ObjectUtils.toLong(val); -// } -// -// /** -// * 转换为Integer类型 -// */ -// public static Integer toInteger(final Object val){ -// return ObjectUtils.toInteger(val); -// } -// -// /** -// * 转换为Boolean类型 -// * 'true', 'on', 'y', 't', 'yes' or '1' (case insensitive) will return true. Otherwise, false is returned. -// */ -// public static Boolean toBoolean(final Object val){ -// return ObjectUtils.toBoolean(val); -// } -// -// /** -// * 转换为字符串 -// * see: ObjectUtils.toString(obj) -// * @param obj -// * @return -// */ -// public static String toString(final Object obj) { -// return ObjectUtils.toString(obj); -// } -// -// /** -// * 如果对象为空,则使用defaultVal值 -// * see: ObjectUtils.toString(obj, defaultVal) -// * @param obj -// * @param defaultVal -// * @return -// */ -// public static String toString(final Object obj, final String defaultVal) { -// return ObjectUtils.toString(obj, defaultVal); -// } -// -// /** -// * 空转空字符串("" to "" ; null to "" ; "null" to "" ; "NULL" to "" ; "Null" to "") -// * @param val 需转换的值 -// * @return 返回转换后的值 -// */ -// public static String toStringIgnoreNull(Object val) { -// return ObjectUtils.toStringIgnoreNull(val); -// } -// -// /** -// * 空对象转空字符串 ("" to defaultVal ; null to defaultVal ; "null" to defaultVal ; "NULL" to defaultVal ; "Null" to defaultVal) -// * @param val 需转换的值 -// * @param defaultVal 默认值 -// * @return 返回转换后的值 -// */ -// public static String toStringIgnoreNull(Object val, String defaultVal) { -// return ObjectUtils.toStringIgnoreNull(val, defaultVal); -// } - -// /** -// * 获得i18n字符串 -// */ -// public static String getMessage(String code, Object[] args) { -// LocaleResolver localLocaleResolver = (LocaleResolver) SpringContextHolder.getBean(LocaleResolver.class); -// HttpServletRequest request = ((ServletRequestAttributes)RequestContextHolder.getRequestAttributes()).getRequest(); -// Locale localLocale = localLocaleResolver.resolveLocale(request); -// return SpringContextHolder.getApplicationContext().getMessage(code, args, localLocale); -// } - - /** - * 首字母大写 - */ - public static String cap(String str){ - return capitalize(str); - } - - /** - * 首字母小写 - */ - public static String uncap(String str){ - return uncapitalize(str); - } - - /** - * 驼峰命名法工具 - * @return - * camelCase("hello_world") == "helloWorld" - * capCamelCase("hello_world") == "HelloWorld" - * uncamelCase("helloWorld") = "hello_world" - */ - public static String camelCase(String s) { - if (s == null) { - return null; - } - - s = s.toLowerCase(); - - StringBuilder sb = new StringBuilder(s.length()); - boolean upperCase = false; - for (int i = 0; i < s.length(); i++) { - char c = s.charAt(i); - - if (c == SEPARATOR) { - upperCase = true; - } else if (upperCase) { - sb.append(Character.toUpperCase(c)); - upperCase = false; - } else { - sb.append(c); - } - } - - return sb.toString(); - } - - /** - * 驼峰命名法工具 - * @return - * camelCase("hello_world") == "helloWorld" - * capCamelCase("hello_world") == "HelloWorld" - * uncamelCase("helloWorld") = "hello_world" - */ - public static String capCamelCase(String s) { - if (s == null) { - return null; - } - s = camelCase(s); - return s.substring(0, 1).toUpperCase() + s.substring(1); - } - - /** - * 驼峰命名法工具 - * @return - * camelCase("hello_world") == "helloWorld" - * capCamelCase("hello_world") == "HelloWorld" - * uncamelCase("helloWorld") = "hello_world" - */ - public static String uncamelCase(String s) { - if (s == null) { - return null; - } - - StringBuilder sb = new StringBuilder(); - boolean upperCase = false; - for (int i = 0; i < s.length(); i++) { - char c = s.charAt(i); - - boolean nextUpperCase = true; - - if (i < (s.length() - 1)) { - nextUpperCase = Character.isUpperCase(s.charAt(i + 1)); - } - - if ((i > 0) && Character.isUpperCase(c)) { - if (!upperCase || !nextUpperCase) { - sb.append(SEPARATOR); - } - upperCase = true; - } else { - upperCase = false; - } - - sb.append(Character.toLowerCase(c)); - } - - return sb.toString(); - } - -// /** -// * 如果不为空,则设置值 -// * @param target -// * @param source -// * @Deprecated 兼容老系统 -// */ -// public static void setValueIfNotBlank(String target, String source) { -// if (isNotBlank(source)){ -// target = source; -// } -// } - - /** - * 转换为JS获取对象值,生成三目运算返回结果 - * @param objectString 对象串 - * 例如:row.user.id - * 返回:!row?'':!row.user?'':!row.user.id?'':row.user.id - */ - public static String jsGetVal(String objectString){ - StringBuilder result = new StringBuilder(); - StringBuilder val = new StringBuilder(); - String[] vals = split(objectString, "."); - for (int i=0; i - * true or 1:显示在左侧:(code)name
- * 2:显示在右侧:name(code)
- * false or null:不显示编码:name - * @param code 编码 - * @param name 名称 - * @return - */ - public static String getTreeNodeName(String isShowCode, String code, String name) { - if ("true".equals(isShowCode) || "1".equals(isShowCode)) { - return "(" + code + ") " + StringUtils.replace(name, " ", ""); - } else if ("2".equals(isShowCode)) { - return StringUtils.replace(name, " ", "") + " (" + code + ")"; - } else { - return StringUtils.replace(name, " ", ""); - } - } - - /** - * 测试代码 - * @param args - */ - public static void main(String[] args) { -// String html = "

__eol__ 科技日报讯 (通讯员辛志向 记者王建高)日前,青岛高新区国家级生态工业示范园区通过了由国家环保部及科技部、商务部三部门联合组织的国家正式验收。

__eol__

__eol__     青岛市委常委、红岛经济区工委书记、管委主任陈飞介绍,建立国家生态工业示范园区是青岛高新区深化和拓展生态创建成果,加快结构调整,推进转型发展,进而辐射带动红岛经济区生态建设的重要抓手。

__eol__

__eol__     自2007年经国家三部委批准创建以来,青岛高新区高度重视,强化措施,始终按照创建工作要求,坚持生态、生活、生产“三生共融”理念,以生态环境的优化带动经济的发展。创建过程中,坚持“科学性规划,高水平建设,生态化发展”的原则,实施“国际化、高端化、低碳化”三大战略,逐步建立起适应循环经济发展的产业体系和政策体系,形成了完善的生态工业园建设框架和循环经济发展机制,实现了经济高速发展与环境持续改善的良性循环。随着发展环境和核心竞争力的不断提升,通过了ISO14001环境管理体系认证,获得了中国最具投资潜力经济园区、国家科技兴贸创新基地、山东省海外高层次人才创新创业基地等称号,在国家级高新区综合评价中连续多年跻身前列,已经成为山东半岛乃至环渤海区域快速成长、极具创新活力和竞争力的蓝色经济特色高科技产业园区。

"; -// html += "
__eol__ 我市积极支持和引导企业、高校院所“走出去”开展国际科技合作,在国外集聚和利用各种创新资源,增强我市企业和科研院所竞争实力。
__eol__
__eol__ 一是在国外设立研发中心。通过合资、并购、控股等方式,在国外设立研发中心和产业园,传播中国文化,提升青岛声誉。如,软控在斯洛伐克设立的研发中心成为我国与中东欧国家合作的成功样板。南车青岛四方积极筹建与泰国等高铁联合研发中心,将成为我国高端成套装备出口的重要研发基地。2013年,我市企业与大学科研机构与国外共建7家联合研发中心。
__eol__
__eol__ 二是利用科技资源和渠道助推中小科技企业“走出去”开发新兴市场。利用尼日利亚总统访华契机,积极向尼方政府代表团推介我市现代农业技术和先进制造业企业。引导我市科技型企业输出技术,拓展西非共同体市场,推动企业转型升级,拓宽“走出去”渠道
"; -// html += "

蓝海技术加以

蓝海技术加以

蓝海技术加以

蓝海技术加以

"; -// html = html.replaceAll("__eol__", ""); -// System.out.println(replaceMobileHtml(html)); - } -} +/** + * Copyright (c) 2013-Now http://jeesite.com All rights reserved. + */ +package com.jeesite.common.lang; + +import java.io.UnsupportedEncodingException; +import java.util.List; +import java.util.Random; +import java.util.regex.Matcher; +import java.util.regex.Pattern; + +import org.apache.commons.lang3.StringEscapeUtils; + +import com.jeesite.common.codec.EncodeUtils; +import com.jeesite.common.collect.ListUtils; + +/** + * 字符串工具类, 继承org.apache.commons.lang3.StringUtils类 + * @author ThinkGem + * @version 2018-1-6 + */ +public class StringUtils extends org.apache.commons.lang3.StringUtils { + + private static final char SEPARATOR = '_'; + private static final String CHARSET_NAME = "UTF-8"; + + /** + * 转换为字节数组 + * @param str + * @return + */ + public static byte[] getBytes(String str){ + if (str != null){ + try { + return str.getBytes(CHARSET_NAME); + } catch (UnsupportedEncodingException e) { + return null; + } + }else{ + return null; + } + } + + /** + * 转换为字节数组 + * @param str + * @return + */ + public static String toString(byte[] bytes){ + try { + return new String(bytes, CHARSET_NAME); + } catch (UnsupportedEncodingException e) { + return EMPTY; + } + } + + /** + * 是否包含字符串 + * @param str 验证字符串 + * @param strs 字符串组 + * @return 包含返回true + */ + public static boolean inString(String str, String... strs){ + if (str != null && strs != null){ + for (String s : strs){ + if (str.equals(trim(s))){ + return true; + } + } + } + return false; + } + + /** + * 是否包含字符串 + * @param str 验证字符串 + * @param strs 字符串组 + * @return 包含返回true + */ + public static boolean inStringIgnoreCase(String str, String... strs){ + if (str != null && strs != null){ + for (String s : strs){ + if (str.equalsIgnoreCase(trim(s))){ + return true; + } + } + } + return false; + } + + /** + * 替换掉HTML标签方法 + */ + public static String stripHtml(String html) { + if (isBlank(html)){ + return ""; + } + //html.replaceAll("\\&[a-zA-Z]{0,9};", "").replaceAll("<[^>]*>", ""); + String regEx = "<.+?>"; + Pattern p = Pattern.compile(regEx); + Matcher m = p.matcher(html); + String s = m.replaceAll(""); + return s; + } + + /** + * 替换为手机识别的HTML,去掉样式及属性,保留回车。 + * @param html + * @return + */ + public static String toMobileHtml(String html){ + if (html == null){ + return ""; + } + return html.replaceAll("<([a-z]+?)\\s+?.*?>", "<$1>"); + } + + /** + * 对txt进行HTML编码,并将\n转换为>br/<、\t转换为    + * @param txt + * @return + */ + public static String toHtml(String txt){ + if (txt == null){ + return ""; + } + return replace(replace(EncodeUtils.escapeHtml(trim(txt)), "\n", "
"), "\t", "    "); + } + + /** + * 缩略字符串(不区分中英文字符) + * @param str 目标字符串 + * @param length 截取长度 + * @return + */ + public static String abbr(String str, int length) { + if (str == null) { + return ""; + } + try { + StringBuilder sb = new StringBuilder(); + int currentLength = 0; + for (char c : stripHtml(StringEscapeUtils.unescapeHtml4(str)).toCharArray()) { + currentLength += String.valueOf(c).getBytes("GBK").length; + if (currentLength <= length - 3) { + sb.append(c); + } else { + sb.append("..."); + break; + } + } + return sb.toString(); + } catch (UnsupportedEncodingException e) { + e.printStackTrace(); + } + return ""; + } + + // 缩略字符串替换Html正则表达式预编译 + private static Pattern p1 = Pattern.compile("<([a-zA-Z]+)[^<>]*>"); + + /** + * 缩略字符串(适应于与HTML标签的) + * @param param 目标字符串 + * @param length 截取长度 + * @return + */ + public static String htmlAbbr(String param, int length) { + if (param == null) { + return ""; + } + StringBuffer result = new StringBuffer(); + int n = 0; + char temp; + boolean isCode = false; // 是不是HTML代码 + boolean isHTML = false; // 是不是HTML特殊字符,如  + for (int i = 0; i < param.length(); i++) { + temp = param.charAt(i); + if (temp == '<') { + isCode = true; + } else if (temp == '&') { + isHTML = true; + } else if (temp == '>' && isCode) { + n = n - 1; + isCode = false; + } else if (temp == ';' && isHTML) { + isHTML = false; + } + try { + if (!isCode && !isHTML) { + n += String.valueOf(temp).getBytes("GBK").length; + } + } catch (UnsupportedEncodingException e) { + e.printStackTrace(); + } + + if (n <= length - 3) { + result.append(temp); + } else { + result.append("..."); + break; + } + } + // 取出截取字符串中的HTML标记 + String tempResult = result.toString().replaceAll("(>)[^<>]*(]*/?>", ""); + // 去掉成对的HTML标记 + tempResult = tempResult.replaceAll("<([a-zA-Z]+)[^<>]*>(.*?)", "$2"); + // 用正则表达式取出标记 + Matcher m = p1.matcher(tempResult); + List endHTML = ListUtils.newArrayList(); + while (m.find()) { + endHTML.add(m.group(1)); + } + // 补全不成对的HTML标记 + for (int i = endHTML.size() - 1; i >= 0; i--) { + result.append(""); + } + return result.toString(); + } + + /** + * 首字母大写 + */ + public static String cap(String str){ + return capitalize(str); + } + + /** + * 首字母小写 + */ + public static String uncap(String str){ + return uncapitalize(str); + } + + /** + * 驼峰命名法工具 + * @return + * camelCase("hello_world") == "helloWorld" + * capCamelCase("hello_world") == "HelloWorld" + * uncamelCase("helloWorld") = "hello_world" + */ + public static String camelCase(String s) { + if (s == null) { + return null; + } + + s = s.toLowerCase(); + + StringBuilder sb = new StringBuilder(s.length()); + boolean upperCase = false; + for (int i = 0; i < s.length(); i++) { + char c = s.charAt(i); + + if (c == SEPARATOR) { + upperCase = true; + } else if (upperCase) { + sb.append(Character.toUpperCase(c)); + upperCase = false; + } else { + sb.append(c); + } + } + + return sb.toString(); + } + + /** + * 驼峰命名法工具 + * @return + * camelCase("hello_world") == "helloWorld" + * capCamelCase("hello_world") == "HelloWorld" + * uncamelCase("helloWorld") = "hello_world" + */ + public static String capCamelCase(String s) { + if (s == null) { + return null; + } + s = camelCase(s); + return s.substring(0, 1).toUpperCase() + s.substring(1); + } + + /** + * 驼峰命名法工具 + * @return + * camelCase("hello_world") == "helloWorld" + * capCamelCase("hello_world") == "HelloWorld" + * uncamelCase("helloWorld") = "hello_world" + */ + public static String uncamelCase(String s) { + if (s == null) { + return null; + } + + StringBuilder sb = new StringBuilder(); + boolean upperCase = false; + for (int i = 0; i < s.length(); i++) { + char c = s.charAt(i); + + boolean nextUpperCase = true; + + if (i < (s.length() - 1)) { + nextUpperCase = Character.isUpperCase(s.charAt(i + 1)); + } + + if ((i > 0) && Character.isUpperCase(c)) { + if (!upperCase || !nextUpperCase) { + sb.append(SEPARATOR); + } + upperCase = true; + } else { + upperCase = false; + } + + sb.append(Character.toLowerCase(c)); + } + + return sb.toString(); + } + + /** + * 转换为JS获取对象值,生成三目运算返回结果 + * @param objectString 对象串 + * 例如:row.user.id + * 返回:!row?'':!row.user?'':!row.user.id?'':row.user.id + */ + public static String jsGetVal(String objectString){ + StringBuilder result = new StringBuilder(); + StringBuilder val = new StringBuilder(); + String[] vals = split(objectString, "."); + for (int i=0; i + * true or 1:显示在左侧:(code)name
+ * 2:显示在右侧:name(code)
+ * false or null:不显示编码:name + * @param code 编码 + * @param name 名称 + * @return + */ + public static String getTreeNodeName(String isShowCode, String code, String name) { + if ("true".equals(isShowCode) || "1".equals(isShowCode)) { + return "(" + code + ") " + StringUtils.replace(name, " ", ""); + } else if ("2".equals(isShowCode)) { + return StringUtils.replace(name, " ", "") + " (" + code + ")"; + } else { + return StringUtils.replace(name, " ", ""); + } + } + +// /** +// * 测试代码 +// * @param args +// */ +// public static void main(String[] args) { +// String html = "

__eol__ 科技日报讯 (通讯员辛志向 记者王建高)日前,青岛高新区国家级生态工业示范园区通过了由国家环保部及科技部、商务部三部门联合组织的国家正式验收。

__eol__

__eol__     青岛市委常委、红岛经济区工委书记、管委主任陈飞介绍,建立国家生态工业示范园区是青岛高新区深化和拓展生态创建成果,加快结构调整,推进转型发展,进而辐射带动红岛经济区生态建设的重要抓手。

__eol__

__eol__     自2007年经国家三部委批准创建以来,青岛高新区高度重视,强化措施,始终按照创建工作要求,坚持生态、生活、生产“三生共融”理念,以生态环境的优化带动经济的发展。创建过程中,坚持“科学性规划,高水平建设,生态化发展”的原则,实施“国际化、高端化、低碳化”三大战略,逐步建立起适应循环经济发展的产业体系和政策体系,形成了完善的生态工业园建设框架和循环经济发展机制,实现了经济高速发展与环境持续改善的良性循环。随着发展环境和核心竞争力的不断提升,通过了ISO14001环境管理体系认证,获得了中国最具投资潜力经济园区、国家科技兴贸创新基地、山东省海外高层次人才创新创业基地等称号,在国家级高新区综合评价中连续多年跻身前列,已经成为山东半岛乃至环渤海区域快速成长、极具创新活力和竞争力的蓝色经济特色高科技产业园区。

"; +// html += "
__eol__ 我市积极支持和引导企业、高校院所“走出去”开展国际科技合作,在国外集聚和利用各种创新资源,增强我市企业和科研院所竞争实力。
__eol__
__eol__ 一是在国外设立研发中心。通过合资、并购、控股等方式,在国外设立研发中心和产业园,传播中国文化,提升青岛声誉。如,软控在斯洛伐克设立的研发中心成为我国与中东欧国家合作的成功样板。南车青岛四方积极筹建与泰国等高铁联合研发中心,将成为我国高端成套装备出口的重要研发基地。2013年,我市企业与大学科研机构与国外共建7家联合研发中心。
__eol__
__eol__ 二是利用科技资源和渠道助推中小科技企业“走出去”开发新兴市场。利用尼日利亚总统访华契机,积极向尼方政府代表团推介我市现代农业技术和先进制造业企业。引导我市科技型企业输出技术,拓展西非共同体市场,推动企业转型升级,拓宽“走出去”渠道
"; +// html += "

蓝海技术加以

蓝海技术加以

蓝海技术加以

蓝海技术加以

"; +// html = html.replaceAll("__eol__", ""); +// System.out.println(replaceMobileHtml(html)); +// } + +}