- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
与此作斗争:
这就是我现在所拥有的一切,但无法找到按预期工作的有效解决方案(除了 Automator 中的操作)。
tell application "Finder"
set myPath to container of (path to me) as text -- SET MAIN PATH
end tell
set AllUrls to {"https://teespring.com/shop/CLASSIC-DODGE-CHARGER-MOP?aid=marketplace&tsmac=marketplace&tsmic=search#pid=212&cid=5819&sid=front", "https://teespring.com/shop/greaser-mechanics-t-shirt?aid=marketplace&tsmac=marketplace&tsmic=campaign#pid=2&cid=2397&sid=front"}
--set ImageSrc to (script to get the src attribute from the class "image_stack__image js-default-img"
--set IMGname to the Page URL where the image is
set dFolder to myPath & "thumbnails"
set fName to IMGname & ".jpg" as string
do shell script ("mkdir -p " & dFolder & "; curl -A/--user-agent " & AllUrls & " >> " & (dFolder & fName))
我们非常感谢您的每一次帮助。谢谢
--
set home_path to (((path to me as text) & "::") as alias) as string
tell application "Safari"
open location "https://teespring.com/shop/CLASSIC-DODGE-CHARGER-MOP?aid=marketplace&tsmac=marketplace&tsmic=search#pid=212&cid=5819&sid=front"
set campaign_thumbnail to do JavaScript "document.querySelector('.image_stack__image').src" in document 1
end tell
do shell script "curl -f " & quoted form of campaign_thumbnail & " -o " & quoted form of (POSIX path of home_path) & "thumbnails/test.jpg"
遵循 CJK 代码:
下载的文件在最后一个/(560.jpg) 后具有相同的结尾我尝试使用“set My_Name to do shell script”uuidgen”并且将其添加到 sh.但我宁愿需要将文件命名为 1.jpg ,2.jpg等。
tell application "Finder" -- get filepath to file container/folder
set myPath to container of (path to me) as text -- SET MAIN PATH
end tell
set allURLs to {"https://teespring.com/shop/CLASSIC-DODGE-CHARGER-MOP?aid=marketplace&tsmac=marketplace&tsmic=search#pid=212&cid=5819&sid=front", "https://teespring.com/shop/dodge-mopar-m?aid=marketplace&tsmac=marketplace&tsmic=search#pid=2&cid=2397&sid=front"}
set JS to "document.querySelector('.image_stack__image').src"
set sh to {"cd ~/desktop/thumbnails;", "curl --remote-name-all ", {}} -- need to set the location to the home folder of the script and the filename to 1.jpg , 2.jpg ..
set the text item delimiters to space
tell application "Safari" to repeat with www in allURLs
set D to (make new document with properties {URL:www})
# Wait until webpage has loaded
tell D to repeat until not (exists)
delay 0.5
end repeat
set the last item of sh to do JavaScript JS in the front document
close the front document
do shell script (sh as text)
结束重复
最佳答案
从类 image_stack__image
的元素中获取所有图像 URL (假设此类的元素是 <img>
元素,并满足共享此类名称的多个图像)这行 JavaScript 将返回 src
的数组属性值:
Array.from(document.querySelectorAll('.image_stack__image'), e=>e.src)
当您使用 do JavaScript
时,AppleScript 会自动将其转换为列表。 Safari 中的命令。
致cURL
目录 "thumbnails"
中的所有 URL在您的主文件夹中,并将每个图像保存在与远程文件相同的名称下,cd
先进入目录,然后cURL
使用--remote-name-all
选项:
cd ~/thumbnails; curl --remote-name-all %url1% %url2% ...
警告:可能不会下载具有异常 URL 的图像,例如通过 CGI 请求动态生成的图像,或 src
的图像。属性包含 base64 编码的数据。事实上,这些都存在于curl
中。请求可能会中断整个请求。
连接从 JavaScript 方法返回的 URL 列表,以便您可以将其直接插入 cURL
,只需将 AppleScript 列表强制为 text
使用space
作为分隔符:
set JS to "Array.from(document.querySelectorAll('.image_stack__image'), e=>e.src);"
set sh to {"cd ~/thumbnails;", "curl --remote-name-all"}
set the text item delimiters to space
tell application "Safari" to tell ¬
the front document to set ¬
the end of sh to ¬
do JavaScript JS
do shell script (sh as text)
然后,通过将适当的代码行包含在 repeat
中,对每个网页 URL 重复完全相同的过程。循环:
set allURLs to {%your list of URLs%}
set JS to "Array.from(document.querySelectorAll('.image_stack__image'),e=>e.src);"
set sh to {"cd ~/thumbnails;", "curl --remote-name-all", {}}
set the text item delimiters to space
tell application "Safari" to repeat with www in allURLs
set D to (make new document with properties {URL:www})
# Wait until webpage has loaded
tell D to repeat until not (exists)
delay 0.5
end repeat
set the last item of sh to do JavaScript JS in the front document
close the front document
do shell script (sh as text)
end repeat
这就是它的基本原理。在 URL 格式不寻常或网页无法加载等情况下,您需要注意错误处理,但您现在拥有完成您请求的步骤的所有工具。
此外,我建议阅读 curl
的联机帮助页(在终端中输入man curl
),并阅读有关--remote-name-all
的信息选项并发现许多您可能会发现有益的其他选项。
但我会尽力帮助您解决遇到的任何小问题或与我所写内容相关的疑问。
关于javascript - Apple 或 Shellscript |获取属性。图像的类名的 "src"并下载它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50175791/
当我尝试通过我的 .exe 文件从 url 下载 .pdf 文件时出现以下错误。 The server committed a protocol violation. Section=Response
我是一家非营利组织的 G Suite 管理员,刚刚发现数据导出功能,这似乎是个人帐户的外卖。 导出文件已准备好,现在可以从 Google Cloud Platform Storage 中的存储桶下载。
导航 引言 总体思路 七牛云相关的配置文件 获取七牛云上传token 相关类定义 核心代码实现 获取七牛云图片下载链接 公开空
这不是后端编程问题。我只能修改标记或脚本(或文档本身)。我在这里问的原因是因为我对适当术语的所有搜索都不可避免地导致有关编程此功能的问题和解决方案。我不是试图通过编程来强制它;我必须找出此 PDF 行
您好,我已在 Google AdSense 中注册,我想使用适用于 iOS 的 SDK,但目前我找不到 SDK 下载链接。 我的申请已获批准。 任何人都知道如何下载这个sdk。 我使用这个链接来描述如
我需要为当前在 SourceForge 上的 github 项目提供二进制文件和文档。在那里,我可以为我需要的下载提供一个目录结构,因为我必须为大约 10 个不同的操作系统提供几个版本。 github
我从 Canvas 下载绘图时遇到问题。这是我的代码: function downloadCanvas(link, canvasId, filename) { link.href =
ASP.NET 项目 我将使用 Azure 进行存储。问题(要求): 在我的项目中,我让注册用户下载文件。但我不希望用户将此下载链接分享给未注册的人(例如:我给注册用户的下载链接只能在他们的计算机上下
我编写了一个servlet,用于检查http header ,但我不知道为什么当页面加载时,它会自动开始下载。 /* * To change this template, choose To
我正在尝试将下载添加到我的网络浏览器,但遇到的问题是获取您尝试下载的文件的名称。这是我的下载代码: engine.locationProperty().addListener(new ChangeLi
我正在尝试下载网站的 html: String encoding = "UTF-8"; HttpContext localContext = new BasicHttpContext();
我制作了一个带有“开始下载”按钮的框架,用于从网站下载 JAR。 问题是每当我点击开始下载按钮时,整个框架就会卡住,直到下载完成,然后就正常了。 我该如何解决这个问题? 这是单击按钮时执行的代码 p
我得到这段代码来实现一些东西,它可以帮助我从给定的 URL 下载文件。 -(void)URLSession:(NSURLSession *)session downloadTask:(NSURLSes
我正在尝试创建一个 Controller 来使用流方法下载和上传文件,在我的例子中,所有文件都作为 Blob 保存在数据库中。我阅读了 Jboss Netty 的文档,但我认为这不是我的最佳解决方案。
下载并保存文件 let destination: DownloadRequest.DownloadFileDestination = { _, _ in // var fileURL = sel
使用 htaccess 我基本上试图禁止访问该页面,即 http://example.com , 但它仍然允许人们下载文件,如果他们有直接链接即 http://example.com/hi.zip .
我正在寻求将脚本与我的控制面板集成,并且由于我是新手脚本编写者而遇到问题。我想做的是用 1 个脚本下载一个文件并解压它。 示例: wget http://example.com/example.tar
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
这个问题在这里已经有了答案: Top techniques to avoid 'data scraping' from a website database (14 个答案) 关闭 5 年前。 我有
这个问题在这里已经有了答案: Reading and parsing email from Gmail using C#, C++ or Python (6 个答案) 关闭 7 年前。 我只是想,是
我是一名优秀的程序员,十分优秀!