List<String> list = new ArrayList<>(); list.add(AuditState.Pass.name()); list.add(AuditState.WaitApprove.name());美化
时间: 2024-04-12 15:28:55 浏览: 26
你可以使用Java的Stream API来美化这个列表,可以通过将列表元素连接起来,使用逗号分隔符,并添加方括号来表示列表。下面是一个示例代码:
```java
List<String> list = new ArrayList<>();
list.add(AuditState.Pass.name());
list.add(AuditState.WaitApprove.name());
String beautifiedList = list.stream().collect(Collectors.joining(", ", "[", "]"));
System.out.println(beautifiedList);
```
输出结果将会是:`[Pass, WaitApprove]`
相关问题
用list<map>将数据库信息展示在前端
好的,以下是一个使用`List<Map>`将数据库信息展示在前端的示例Java代码:
```java
// 定义一个获取数据库中所有信息的方法
public List<Map<String, Object>> getAllData() {
Connection conn = null;
Statement stmt = null;
ResultSet rs = null;
List<Map<String, Object>> dataList = new ArrayList<>();
try {
// 获取数据库连接
conn = DriverManager.getConnection(DB_URL, USER, PASS);
// 执行查询语句
stmt = conn.createStatement();
String sql = "SELECT * FROM table_name";
rs = stmt.executeQuery(sql);
// 处理结果集
ResultSetMetaData metaData = rs.getMetaData();
int columnCount = metaData.getColumnCount();
while (rs.next()) {
Map<String, Object> dataMap = new HashMap<>();
for (int i = 1; i <= columnCount; i++) {
dataMap.put(metaData.getColumnName(i), rs.getObject(i));
}
dataList.add(dataMap);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
// 关闭资源
try {
if (rs != null) {
rs.close();
}
if (stmt != null) {
stmt.close();
}
if (conn != null) {
conn.close();
}
} catch (SQLException e) {
e.printStackTrace();
}
}
return dataList;
}
```
在这个方法中,我们通过执行查询语句获取数据库中的所有数据,并将结果保存在一个`List<Map>`中。每个`Map`对象表示一条数据,其中`Map`的key表示列名,value表示对应的值。
接下来,我们将这个`List<Map>`传递给前端页面进行展示。以下是一个简单的JSP页面示例,在这个页面中,我们使用JSTL标签库来遍历`List<Map>`,并将每个`Map`中的数据展示出来:
```jsp
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<title>Database Data</title>
</head>
<body>
<table>
<thead>
<tr>
<th>Column 1</th>
<th>Column 2</th>
<th>Column 3</th>
</tr>
</thead>
<tbody>
<c:forEach var="data" items="${dataList}">
<tr>
<td>${data.column1}</td>
<td>${data.column2}</td>
<td>${data.column3}</td>
</tr>
</c:forEach>
</tbody>
</table>
</body>
</html>
```
在这个JSP页面中,我们使用`<c:forEach>`标签来遍历`List<Map>`中的每个`Map`对象,并使用`${data.key}`的方式来获取每个key对应的值。这样就可以将数据库中的数据展示在前端页面上了。
将下列java代码改为python代码:blic static void scan(String host, int startPort, int endPort) throws InterruptedException { List<Integer> portList = new ArrayList<>(); final CountDownLatch latch = new CountDownLatch(endPort - startPort + 1); for (int port = startPort; port <= endPort; port++) { int finalPort = port; Thread thread = new Thread(new Runnable() { @Override public void run() { try { Socket socket = new Socket(); socket.connect(new InetSocketAddress(host, finalPort), 100); System.out.println("TCP端口" + finalPort + "开放"); portList.add(finalPort); } catch (Exception e) { } try { DatagramSocket dsocket = new DatagramSocket(finalPort); dsocket.close(); } catch (SocketException e) { portList.add(finalPort); System.out.println("UDP端口" + finalPort + "开放"); } latch.countDown(); } }); thread.start(); } latch.await(); portList.sort(new Comparator<Integer>() { @Override public int compare(Integer o1, Integer o2) { return o1.compareTo(o2); } }); }
由于Python是一种解释型语言,因此需要使用不同的模块和语言结构来实现相同的功能。以下是一个类似的Python代码:
import socket
import threading
def scan(host, startPort, endPort):
portList = []
lock = threading.Lock()
def checkPort(port):
try:
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.settimeout(0.1)
result = sock.connect((host, port))
with lock:
portList.append(port)
print("TCP端口" + str(port) + "开放")
sock.close()
except:
pass
try:
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
sock.settimeout(0.1)
sock.bind((host, port))
with lock:
portList.append(port)
print("UDP端口" + str(port) + "开放")
sock.close()
except:
pass
threads = []
for port in range(startPort, endPort+1):
t = threading.Thread(target=checkPort, args=(port,))
threads.append(t)
t.start()
for t in threads:
t.join()
portList.sort()
return portList
# 示例
if __name__ == "__main__":
host = "127.0.0.1"
startPort = 1
endPort = 65535
openPorts = scan(host, startPort, endPort)
print(openPorts)
相关推荐
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)