主頁 > 軟體設計 > 呼叫高德API,通過輸入的地址,如省份、市、區獲取經緯度 ,通過輸入的經緯度,獲取區域詳情

呼叫高德API,通過輸入的地址,如省份、市、區獲取經緯度 ,通過輸入的經緯度,獲取區域詳情

2020-09-14 18:41:29 軟體設計

一、pom

<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.java.gaode.GaoDeDemo</groupId>
<artifactId>GaoDeDemo</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>com.google.collections</groupId>
<artifactId>google-collections</artifactId>
<version>1.0</version>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>20.0</version>
</dependency>
<dependency>
<groupId>commons-httpclient</groupId>
<artifactId>commons-httpclient</artifactId>
<version>3.1</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.8.1</version>
</dependency>
<dependency>
<groupId>org.apache.httpcomponents</groupId>
<artifactId>httpclient</artifactId>
<version>4.5.9</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.31</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-client</artifactId>
<version>1.19.1</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.28</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.1.10.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.10.RELEASE</version>
</dependency>
</dependencies>
</project>

二、HttpClientUtils工具類
package com.java.gao;

/**
* @ClassName: HttpClientUtils
* @Description:
* @Version: v1.0.0
* @Author: Fu Hao
* @Date: 2019/10/22 0022 下午 8:15
* Modification History:
* Date Author Version Description
* -------------------------------------------------------------
* 2019/10/22 0022 Fu Hao v1.0.0 創建
*/
import com.google.common.base.Function;
import com.google.common.collect.FluentIterable;
import com.google.common.collect.Lists;
import org.apache.commons.httpclient.HttpStatus;
import org.apache.commons.httpclient.NoHttpResponseException;
import org.apache.commons.lang3.StringUtils;
import org.apache.http.*;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.HttpRequestRetryHandler;
import org.apache.http.client.ResponseHandler;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.entity.UrlEncodedFormEntity;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.client.protocol.HttpClientContext;
import org.apache.http.client.utils.URLEncodedUtils;
import org.apache.http.config.ConnectionConfig;
import org.apache.http.config.Registry;
import org.apache.http.config.RegistryBuilder;
import org.apache.http.config.SocketConfig;
import org.apache.http.conn.ConnectTimeoutException;
import org.apache.http.conn.socket.ConnectionSocketFactory;
import org.apache.http.conn.socket.PlainConnectionSocketFactory;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.message.BasicNameValuePair;
import org.apache.http.protocol.HttpContext;
import org.apache.http.ssl.SSLContexts;
import org.apache.http.util.EntityUtils;

import javax.net.ssl.SSLException;
import javax.net.ssl.SSLHandshakeException;
import java.io.IOException;
import java.io.InterruptedIOException;
import java.net.UnknownHostException;
import java.nio.charset.CodingErrorAction;
import java.util.List;
import java.util.Map;


/**
* HttpClient工具類
*/
public class HttpClientUtils {

/**
* 連接池最大連接數
*/
private static final int MAX_TOTAL_CONNECTIONS = 4000;

/**
* 設定每個路由上的默認連接個數
*/
private static final int DEFAULT_MAX_PER_ROUTE = 200;

/**
* 請求的請求超時時間 單位:毫秒
*/
private static final int REQUEST_CONNECTION_TIMEOUT = 8 * 1000;

/**
* 請求的等待資料超時時間 單位:毫秒
*/
private static final int REQUEST_SOCKET_TIMEOUT = 8 * 1000;

/**
* 請求的連接超時時間 單位:毫秒
*/
private static final int REQUEST_CONNECTION_REQUEST_TIMEOUT = 5 * 1000;

/**
* 連接閑置多久后需要重新檢測 單位:毫秒
*/
private static final int VALIDATE_AFTER_IN_ACTIVITY = 2 * 1000;

/**
* 關閉Socket時,要么發送完所有資料,要么等待多少秒后,就關閉連接,此時socket.close()是阻塞的 單位秒
*/
private static final int SOCKET_CONFIG_SO_LINGER = 60;

/**
* 接收資料的等待超時時間,即讀超時時間,單位ms
*/
private static final int SOCKET_CONFIG_SO_TIMEOUT = 5 * 1000;
/**
* 重試次數
*/
private static int RETRY_COUNT = 5;
/**
* 宣告為 static volatile,會迫使執行緒每次讀取時作為一個全域變數讀取
*/
private static volatile CloseableHttpClient httpClient = null;


/**
* @param uri
* @return String
* @description get請求方式
* @author: long.he01
*/
public static String doGet(String uri) {

String responseBody;
HttpGet httpGet = new HttpGet(uri);
try {
httpGet.setConfig(getRequestConfig());
responseBody = executeRequest(httpGet);
} catch (IOException e) {
throw new RuntimeException("httpclient doGet方法例外 ", e);
} finally {
httpGet.releaseConnection();
}

return responseBody;
}

/**
* @param uri
* @param params
* @return string
* @description map引數get請求, 此方法會將map引數拼接到連接地址上,
*/
public static String doGet(String uri, Map<String, String> params) {

return doGet(getGetUrlFromParams(uri, params));

}

/**
* @param uri
* @param params
* @return String
* @description 根據map引數拼接完整的url地址
*/
private static String getGetUrlFromParams(String uri, Map<String, String> params) {


List<BasicNameValuePair> resultList = FluentIterable.from(params.entrySet()).transform(
new Function<Map.Entry<String, String>, BasicNameValuePair>() {
@Override
public BasicNameValuePair apply(Map.Entry<String, String> innerEntry) {

return new BasicNameValuePair(innerEntry.getKey(), innerEntry.getValue());
}

}).toList();

String paramSectionOfUrl = URLEncodedUtils.format(resultList, Consts.UTF_8);
StringBuffer resultUrl = new StringBuffer(uri);

if (StringUtils.isEmpty(uri)) {
return uri;
} else {
if (!StringUtils.isEmpty(paramSectionOfUrl)) {
if (uri.endsWith("?")) {
resultUrl.append(paramSectionOfUrl);
} else {
resultUrl.append("?").append(paramSectionOfUrl);
}
}
return resultUrl.toString();
}


}


/**
* @param uri
* @param params
* @return String
* @description map引數的post請求方法
*/
public static String doPost(String uri, Map<String, String> params) {

String responseBody;
HttpPost httpPost = new HttpPost(uri);
try {
List<NameValuePair> nvps = Lists.newArrayList();
for (Map.Entry<String, String> entry : params.entrySet()) {
String key = entry.getKey();
String value = https://www.cnblogs.com/xiaoshenke/p/entry.getValue();
nvps.add(new BasicNameValuePair(key, value));
}
httpPost.setEntity(new UrlEncodedFormEntity(nvps, Consts.UTF_8));
httpPost.setConfig(getRequestConfig());
responseBody = executeRequest(httpPost);

} catch (Exception e) {
throw new RuntimeException("httpclient doPost方法例外 ", e);
} finally {
httpPost.releaseConnection();
}

return responseBody;

}


/**
* @param uri
* @param param
* @param contentType 根據具體請求情況指定,比如json可以是 ContentType.APPLICATION_JSON
* @return String
* @description 帶單string引數執行post方法
*/
public static String doPost(String uri, String param, ContentType contentType) {

String responseBody;
HttpPost httpPost = new HttpPost(uri);
try {
StringEntity reqEntity = new StringEntity(param, contentType);
httpPost.setEntity(reqEntity);
httpPost.setConfig(getRequestConfig());
responseBody = executeRequest(httpPost);

} catch (IOException e) {
throw new RuntimeException("httpclient doPost方法例外 ", e);
} finally {
httpPost.releaseConnection();
}
return responseBody;
}

/**
* @return RequestConfig
* @description: 獲得請求配置資訊
*/
private static RequestConfig getRequestConfig() {


RequestConfig defaultRequestConfig = RequestConfig.custom()
//.setCookieSpec(CookieSpecs.DEFAULT)
.setExpectContinueEnabled(true)
//.setTargetPreferredAuthSchemes(Arrays.asList(AuthSchemes.NTLM, AuthSchemes.DIGEST))
//.setProxyPreferredAuthSchemes(Arrays.asList(AuthSchemes.BASIC))
.build();

return RequestConfig.copy(defaultRequestConfig)
.setSocketTimeout(REQUEST_CONNECTION_TIMEOUT)
.setConnectTimeout(REQUEST_SOCKET_TIMEOUT)
.setConnectionRequestTimeout(REQUEST_CONNECTION_REQUEST_TIMEOUT)
.build();

}


/**
* @param method
* @return String
* @throws IOException
* @description 通用執行請求方法
*/
private static String executeRequest(HttpUriRequest method) throws IOException {

ResponseHandler<String> responseHandler = new ResponseHandler<String>() {

@Override
public String handleResponse(final HttpResponse response) throws IOException {

int status = response.getStatusLine().getStatusCode();
String result;
if (status >= HttpStatus.SC_OK && status < HttpStatus.SC_MULTIPLE_CHOICES) {
HttpEntity entity = response.getEntity();
result = entity != null ? EntityUtils.toString(entity) : null;
EntityUtils.consume(entity);
return result;
} else {
throw new ClientProtocolException("Unexpected response status: " + status);
}
}

};
String result = getHttpClientInstance().execute(method, responseHandler);

return result;
}


/**
* @return CloseableHttpClient
* @description 單例獲取httpclient實體
*/
private static CloseableHttpClient getHttpClientInstance() {

if (httpClient == null) {
synchronized (CloseableHttpClient.class) {
if (httpClient == null) {
httpClient = HttpClients.custom().setConnectionManager(initConfig()).setRetryHandler(getRetryHandler()).build();
}
}
}
return httpClient;

}

/**
* @return HttpRequestRetryHandler
* @description :獲取重試handler
*/
private static HttpRequestRetryHandler getRetryHandler() {

// 請求重試處理
return new HttpRequestRetryHandler() {
@Override
public boolean retryRequest(IOException exception,
int executionCount, HttpContext context) {
if (executionCount >= RETRY_COUNT) {
// 假設已經重試了5次,就放棄
return false;
}
if (exception instanceof NoHttpResponseException) {
// 假設server丟掉了連接,那么就重試
return true;
}
if (exception instanceof SSLHandshakeException) {
// 不要重試SSL握手例外
return false;
}
if (exception instanceof InterruptedIOException) {
// 超時
return false;
}
if (exception instanceof UnknownHostException) {
// 目標server不可達
return false;
}
if (exception instanceof ConnectTimeoutException) {
// 連接被拒絕
return false; }

if (exception instanceof SSLException) {
// SSL握手例外
return false; } HttpRequest request = HttpClientContext.


adapt(context).getRequest();
// 假設請求是冪等的,就再次嘗試
return !(request instanceof HttpEntityEnclosingRequest); } }; }

/**
* @return PoolingHttpClientConnectionManager
* @description 初始化連接池等配置資訊
*/
private static PoolingHttpClientConnectionManager initConfig() { Registry<ConnectionSocketFactory> socketFactoryRegistry = RegistryBuilder.<ConnectionSocketFactory>

create() .register(
"http", PlainConnectionSocketFactory.INSTANCE) .register(
"https", new SSLConnectionSocketFactory(SSLContexts.createSystemDefault())) .build(); PoolingHttpClientConnectionManager connManager =


new PoolingHttpClientConnectionManager(socketFactoryRegistry);

/**
* 以下引數設定含義分別為:
* 1 是否立即發送資料,設定為true會關閉Socket緩沖,默認為false
* 2 是否可以在一個行程關閉Socket后,即使它還沒有釋放埠,其它行程還可以立即重用埠
* 3 接收資料的等待超時時間,單位ms
* 4 關閉Socket時,要么發送完所有資料,要么等待多少秒后,就關閉連接,此時socket.close()是阻塞的
* 5 開啟監視TCP連接是否有效
* 其中setTcpNoDelay(true)設定是否啟用Nagle演算法,設定true后禁用Nagle演算法,默認為false(即默認啟用Nagle演算法),
* Nagle演算法試圖通過減少分片的數量來節省帶寬,當應用程式希望降低網路延遲并提高性能時,
* 它們可以關閉Nagle演算法,這樣資料將會更早地發 送,但是增加了網路消耗, 單位為:毫秒
*/

SocketConfig socketConfig = SocketConfig.custom() .setTcpNoDelay(
true) .setSoReuseAddress(
true) .setSoTimeout(
SOCKET_CONFIG_SO_TIMEOUT)
//.setSoLinger(SOCKET_CONFIG_SO_LINGER)
//.setSoKeepAlive(true)
.build(); connManager.setDefaultSocketConfig(socketConfig); connManager.setValidateAfterInactivity(


VALIDATE_AFTER_IN_ACTIVITY); ConnectionConfig connectionConfig = ConnectionConfig.

custom() .setMalformedInputAction(CodingErrorAction.
IGNORE) .setUnmappableInputAction(CodingErrorAction.
IGNORE) .setCharset(Consts.
UTF_8) .build(); connManager.setDefaultConnectionConfig(connectionConfig); connManager.setDefaultMaxPerRoute(


DEFAULT_MAX_PER_ROUTE); connManager.setMaxTotal(
MAX_TOTAL_CONNECTIONS);
return connManager; }}


三、GaoDeMapUtils工具類

package com.java.gao;

import com.sun.deploy.net.URLEncoder;

import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;

/**
* @ClassName: GaoDeMapUtils
* @Description:
* @Version: v1.0.0
* @Author: Fu Hao
* @Date: 2019/10/22 0022 下午 8:05
* Modification History:
* Date Author Version Description
* -------------------------------------------------------------
* 2019/10/22 0022 Fu Hao v1.0.0 創建
*/

public class GaoDeMapUtils {


/**
* 高德地圖請求秘鑰
*/
private static final String KEY = "高德官網申請";
/**
* 回傳值型別
*/
private static final String OUTPUT = "JSON";
/**
* 根據地名獲取高德經緯度
*/
private static final String GET_LNG_LAT_URL = "http://restapi.amap.com/v3/geocode/geo";
/**
* 根據高德經緯度獲取地名
*/
private static final String GET_ADDRESS_URL = "http://restapi.amap.com/v3/geocode/regeo";

/**
* 根據高德經緯度獲取地址資訊
*
* @param gdLon 高德地圖經度
* @param gdLat 高德地圖緯度
* @return
*/
public static String getAddressByLonLat(double gdLon, double gdLat) {

String location = gdLon + "," + gdLat;
Map<String, String> params = new HashMap<>();
params.put("location", location);

try {
// 拼裝url,output回傳值型別,GET_ADDRESS_URL根據高德經緯度獲取地名
String url = jointUrl(params, OUTPUT, KEY, GET_ADDRESS_URL);
// 呼叫高德SDK
return HttpClientUtils.doPost(url, params);
// 決議Json字串,獲取城市名稱
// JSONObject jsonObject = JSON.parseObject(jsonResult);
// String regeocode = jsonObject.getString("regeocode");
// JSONObject regeocodeObj = JSON.parseObject(regeocode);
// String address = regeocodeObj.getString("formatted_address");
// 組裝結果
// result.put(location, address);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}

/**
* 根據地址資訊獲取高德經緯度
*
* @param address 地址資訊
* @return
*/
public static String getLonLarByAddress(String address) {
Map<String, String> params = new HashMap<>();
params.put("address", address);

// Map<String, String> result = new HashMap<>();
try {
// 拼裝url
String url = jointUrl(params, OUTPUT, KEY, GET_LNG_LAT_URL);
// 呼叫高德地圖SDK
return HttpClientUtils.doPost(url, params);

// 決議JSON字串,取到高德經緯度
// JSONObject jsonObject = JSON.parseObject(jsonResult);
// JSONArray geocodes = jsonObject.getJSONArray("geocodes");
// String geocode = JSON.toJSONString(geocodes.get(0));
// JSONObject geocodeObj = JSON.parseObject(geocode);
// String lonAndLat = geocodeObj.getString("location");
// 組裝結果
// result.put(address, lonAndLat);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}

/**
* 拼接請求字串
*
* @param params
* @param output
* @param key
* @param url
* @return
* @throws IOException
*/
private static String jointUrl(Map<String, String> params, String output, String key, String url) throws IOException {
StringBuilder baseUrl = new StringBuilder();
baseUrl.append(url);

int index = 0;
Set<Map.Entry<String, String>> entrys = params.entrySet();
for (Map.Entry<String, String> param : entrys) {
// 判斷是否是第一個引數
if (index == 0) {
baseUrl.append("?");
} else {
baseUrl.append("&");
}
baseUrl.append(param.getKey()).append("=").append(URLEncoder.encode(param.getValue(), "utf-8"));
index++;
}
baseUrl.append("&output=").append(output).append("&key=").append(key);

return baseUrl.toString();
}


}


四、測驗
package com.java.gao;

/**gao包里的三個方法是根據經緯度獲取區域或者根據區域獲取經緯度
* 本方法兩個功能:通過輸入的地址,如省份、市、區獲取經緯度
* 通過輸入的經緯度,獲取地址值
* 總共三個類:ControllerGaoDeMapUtilsHttpClientUtils工具類
* @ClassName: Controller
* @Description:
* @Version: v1.0.0
* @Author: Fu Hao
* @Date: 2019/10/22 0022 下午 8:23
* Modification History:
* Date Author Version Description
* -------------------------------------------------------------
* 2019/10/22 0022 Fu Hao v1.0.0 創建
*/


public class Controller {
public static void main(String[] args) {
System.out.println(GaoDeMapUtils.getLonLarByAddress("中國"));

System.out.println("---------------------------------------");

System.out.println(GaoDeMapUtils.getAddressByLonLat(118,29));

}
}
 
 

轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/37792.html

標籤:設計模式

上一篇:設計模式------中介者模式

下一篇:通俗易懂設計模式決議——備忘錄模式

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 面試突擊第一季,第二季,第三季

    第一季必考 https://www.bilibili.com/video/BV1FE411y79Y?from=search&seid=15921726601957489746 第二季分布式 https://www.bilibili.com/video/BV13f4y127ee/?spm_id_fro ......

    uj5u.com 2020-09-10 05:35:24 more
  • 第三單元作業總結

    1.前言 這應該是本學期最后一次寫作業總結了吧。總體來說,對作業的節奏也差不多掌握了,作業做起來的效率也更高了。雖然和之前的作業一樣,作業中都要用到新的知識,但是相比之前,更加懂得了如何利用工具以及資料。雖然之間卡過殼,但總體而言,這幾次作業還算完成的比較好。 2.作業程序總結 相比前兩個單元,此單 ......

    uj5u.com 2020-09-10 05:35:41 more
  • 北航OO(2020)第四單元博客作業暨課程總結博客

    北航OO(2020)第四單元博客作業暨課程總結博客 本單元作業的架構設計 在本單元中,由于UML圖具有比較清晰的樹形結構,因此我對其中需要進行查詢操作的元素進行了包裝,在樹的父節點中存盤所有孩子的參考。考慮到性能問題,我采用了快取機制,一次查詢后盡可能快取已經遍歷過的資訊,以減少遍歷次數。 本單元我 ......

    uj5u.com 2020-09-10 05:35:48 more
  • BUAA_OO_第四單元

    一、UML決議器設計 ? 先看下題目:第四單元實作一個基于JDK 8帶有效性檢查的UML(Unified Modeling Language)類圖,順序圖,狀態圖分析器 MyUmlInteraction,實際上我們要建立一個有向圖模型,UML中的物件(元素)可能與同級元素連接,也可與低級元素相連形成 ......

    uj5u.com 2020-09-10 05:35:54 more
  • 6.1邏輯運算子

    邏輯運算子 1. && 短路與 運算式1 && 運算式2 01.運算式1為true并且運算式2也為true 整體回傳為true 02.運算式1為false,將不會執行運算式2 整體回傳為false 03.只要有一個運算式為false 整體回傳為false 2. || 短路或 運算式1 || 運算式2 ......

    uj5u.com 2020-09-10 05:35:56 more
  • BUAAOO 第四單元 & 課程總結

    1. 第四單元:StarUml檔案決議 本單元采用了圖模型決議UML。 UML檔案可以抽象為圖、子圖、邊的邏輯結構。 在實作中,圖的節點包括類、介面、屬性,子圖包括狀態圖、順序圖等。 采用了三次遍歷UML元素的方法建圖,第一遍遍歷建點,第二、三次遍歷設定屬性、連邊,實作圖物件的初始化。這里借鑒了一些 ......

    uj5u.com 2020-09-10 05:36:06 more
  • 談談我對C# 多型的理解

    面向物件三要素:封裝、繼承、多型。 封裝和繼承,這兩個比較好理解,但要理解多型的話,可就稍微有點難度了。今天,我們就來講講多型的理解。 我們應該經常會看到面試題目:請談談對多型的理解。 其實呢,多型非常簡單,就一句話:呼叫同一種方法產生了不同的結果。 具體實作方式有三種。 一、多載 多載很簡單。 p ......

    uj5u.com 2020-09-10 05:36:09 more
  • Python 資料驅動工具:DDT

    背景 python 的unittest 沒有自帶資料驅動功能。 所以如果使用unittest,同時又想使用資料驅動,那么就可以使用DDT來完成。 DDT是 “Data-Driven Tests”的縮寫。 資料:http://ddt.readthedocs.io/en/latest/ 使用方法 dd. ......

    uj5u.com 2020-09-10 05:36:13 more
  • Python里面的xlrd模塊詳解

    那我就一下面積個問題對xlrd模塊進行學習一下: 1.什么是xlrd模塊? 2.為什么使用xlrd模塊? 3.怎樣使用xlrd模塊? 1.什么是xlrd模塊? ?python操作excel主要用到xlrd和xlwt這兩個庫,即xlrd是讀excel,xlwt是寫excel的庫。 今天就先來說一下xl ......

    uj5u.com 2020-09-10 05:36:28 more
  • 當我們創建HashMap時,底層到底做了什么?

    jdk1.7中的底層實作程序(底層基于陣列+鏈表) 在我們new HashMap()時,底層創建了默認長度為16的一維陣列Entry[ ] table。當我們呼叫map.put(key1,value1)方法向HashMap里添加資料的時候: 首先,呼叫key1所在類的hashCode()計算key1 ......

    uj5u.com 2020-09-10 05:36:38 more
最新发布
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:20:47 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:20:25 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:20:17 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:20:10 more
  • 【中介者設計模式詳解】C/Java/JS/Go/Python/TS不同語言實作

    * 中介者模式是一種行為型設計模式,它可以用來減少類之間的直接依賴關系,
    * 將物件之間的通信封裝到一個中介者物件中,從而使得各個物件之間的關系更加松散。
    * 在中介者模式中,物件之間不再直接相互互動,而是通過中介者來中轉訊息。 ......

    uj5u.com 2023-04-20 08:19:44 more
  • 露天煤礦現場調研和交流案例分享

    他們集團的資訊化公司及研究院在一個礦區正在做智能礦山的統一平臺的 試點,專案投資大概1億,包括了礦山的各方面的內容,顯示得我們這次交流有點多余。他們2年前開始做智能礦山的規劃,有很多煤礦行業專家的加持,他們的描述是非常完美,但是去年底應該上線的平臺,現在還沒有看到影子。他們確實有很多場景需求,但是被... ......

    uj5u.com 2023-04-20 08:19:07 more
  • 《社區人員管理》實戰案例設計&個人案例分享

    設計是一個讓人夢想成真程序,開始編碼、測驗、除錯之前進行需求分析和架構設計,才能保證關鍵方面都做正確 ......

    uj5u.com 2023-04-20 08:18:57 more
  • 軟體架構生態化-多角色交付的探索實踐

    作為一個技術架構師,不僅僅要緊跟行業技術趨勢,還要結合研發團隊現狀及痛點,探索新的交付方案。在日常中,你是否遇到如下問題 “ 業務需求排期長研發是瓶頸;非研發角色感受不到研發技改提效的變化;引入ISV 團隊又擔心質量和安全,培訓周期長“等等,基于此我們探索了一種新的技術體系及交付方案來解決如上問題。 ......

    uj5u.com 2023-04-20 08:18:49 more
  • 05單件模式

    #經典的單件模式 public class Singleton { private static Singleton uniqueInstance; //一個靜態變數持有Singleton類的唯一實體。 // 其他有用的實體變數寫在這里 //構造器宣告為私有,只有Singleton可以實體化這個類! ......

    uj5u.com 2023-04-19 08:42:51 more
  • 【架構與設計】常見微服務分層架構的區別和落地實踐

    軟體工程的方方面面都遵循一個最基本的道理:沒有銀彈,架構分層模型更是如此,每一種都有各自優缺點,所以請根據不同的業務場景,并遵循簡單、可演進這兩個重要的架構原則選擇合適的架構分層模型即可。 ......

    uj5u.com 2023-04-19 08:42:41 more