Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

双班制

Posted on 2023-11-28

我已经数不清看过《实习医生风云》的次数了,目前我正在重新观看《实习医生格蕾》第三次(也许是第四次?)。我注意到有很多演员都出现在这两集中,而且似乎每隔一集都有出现。经过一些数据争论后,我得到了一个实际的答案:两个系列中都有 28 名演员出演。

想法

我认为在网站上展示这一点并突出我所说的“双医生”:即在两部剧中都扮演医生的演员,会很有趣。该网站名为DoubleShift ,它有一个我设计的漂亮徽标:

双班标志

我向大卫提到了这个想法,他问豪斯的数据如何。因此,我将《豪斯医生》添加到了我的数据集中:78 位演员出现在《实习医生格蕾》和《豪斯医生》中,48 位演员出现在《实习医生风云》和《豪斯医生》中。我还添加了ER,因为它也有很多交叉。

我简单地添加了综合医院,因为它已经运行了很长时间,但只有一位女演员曾出演过任何其他节目,所以我再次删除了它。此外,再添加一场演出也会产生更多的排列。

处理数据

为了获取每个节目的演员数据,我使用了电影数据库 API ,它有一个方便的“Aggregate Credits”端点,用于获取所有季节的节目中的所有演员。然后,我通过 TMDB ID 将该数据映射到键控对象:

 const res = await fetch ( ` https://api.themoviedb.org/3/tv/ ${ show . id } /aggregate_credits?&series_id=1416&language=en-US ` , {
headers : {
'Authorization' : ` Bearer ${ process . env . API_KEY } ` ,
'accept' : 'application/json'
}
} )
const json = await res . json ( )
const data = { }

json . cast . forEach ( ( actor ) => {
data [ actor . id ] = {
... actor ,
}
} )

要找到参加过这两场演出的演员, filter就可以达到目的:

 const intersection = Object . keys ( showData [ showOne ] ) . filter ( element => Object . keys ( showData [ showTwo ] ) . includes ( element ) )

// console.log(intersection)
// [123, 3456, 3456]

我像往常一样使用Eleventy ,因为它的数据文件非常适合处理此类事情,并且使用 nunjucks 可以轻松输出我想要的内容。我决定避免在网站本身上使用 javascript,因此我使用 CSS 和单选按钮来显示和隐藏每个显示组合。

 #show-greys-scrubs {
display : none ;
}

#greys-scrubs:checked ~ #show-greys-scrubs {
display : none ;
}

值得注意的是,当使用后续同级组合器( ~ ) 时,两个元素必须是同一父元素的子元素,因此我不能将单选按钮放在自己的容器内,这使得对它们进行样式设计稍微困难一些,但要付出很小的代价这里不要依赖JS。

在此处查看 DoubleShift 站点,您可以在 GitHub 上查看源代码

原文: https://rknight.me/doubleshift/

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme