0


[02 Selenium获取图片资源]Selenium

一. 以下是实现selenium获取图片资源的步骤+代码

** //1.定义图片下载的路径集合**

** private static List<String> paths=new ArrayList<>();
//2.定义图片下载网址**
private static final String PATH="https://www.139ys.com/";
//3.下载图片保存到指定路径
private static final String DIR="D:\img\";

//4.写一个获取图片类

  1. private static void getImg(){
  2. //设置驱动
  3. System.setProperty("webdriver.chrome.driver","D:\\chromedriver.exe");
  4. //创建驱动
  5. WebDriver driver=new ChromeDriver();
  6. //与将要爬取的网站建立连接
  7. driver.get(PATH);
  8. sleep(3);
  9. //获取图片资源
  10. List<WebElement> elements = driver.findElements(By.xpath("/html/body/div[2]/div/div[1]/div/div[2]/ul/li"));
  11. //循环遍历获取图片下载路径
  12. for (WebElement eles:elements) {
  13. WebElement a = eles.findElement(By.tagName("a"));
  14. paths.add( a.getAttribute("data-original"));
  15. }
  16. //关闭释放资源
  17. driver.close();
  18. driver.quit();
  19. }

//5.写一个保存图片的类

  1. private static void saveImg(String path){
  2. try {
  3. URL url=new URL(path);
  4. // 定义图片名称
  5. String img=System.currentTimeMillis()+".jpg";
  6. //定义·输入流
  7. InputStream is=new DataInputStream(url.openStream());
  8. //定义输出流
  9. OutputStream out=new FileOutputStream(new File(DIR+img));
  10. // 定义每次读取长度
  11. int len=0;
  12. byte[] size=new byte[1024];
  13. //循环读写流
  14. while((len=is.read(size))!=-1){
  15. out.write(size,0,len);
  16. }
  17. //关闭
  18. is.close();
  19. out.close();
  20. } catch (Exception e) {
  21. e.printStackTrace();
  22. }
  23. }

//根据需要可以写一个sleep睡眠时间方法

  1. //获取数据时设置休眠时间
  2. public static void sleep(int s){
  3. try {
  4. Thread.sleep(s*1000L);
  5. } catch (InterruptedException e) {
  6. e.printStackTrace();
  7. }
  8. }

//最后调用方法,执行、

  1. public static void main(String[] args) {
  2. getImg();
  3. for (String str:paths){
  4. System.out.println(str);
  5. saveImg(str);
  6. }
  7. }

这样就可以获取图片了

标签: selenium java 前端

本文转载自: https://blog.csdn.net/weixin_62026595/article/details/126749586
版权归原作者 对太阳心动 所有, 如有侵权,请联系我们删除。

“[02 Selenium获取图片资源]Selenium”的评论:

还没有评论