Python3,自从我掌握了Doscoart库, 我对艺术的成就越来越高.

1、引言

小屌丝:鱼哥,最近在忙啥?

小鱼:咱俩陌生了?

小屌丝:何出此言?

小鱼:你说的话又嘛意思呢?

小屌丝:我的意思, 最近看你这整理各种资料,貌似很忙的样子?

小鱼:我平时不也这么忙嘛

小屌丝:鱼哥, 还能正常唠嗑嘛?

小鱼:我又没说不能唠嗑。

小屌丝:鱼哥,行… 非常行…

小鱼:男人,怎么能不行!

小屌丝:…

小鱼:~ ~

小屌丝:discoart模块知道吗?

小鱼:貌似, 大概,可能,或许,知道。

小屌丝:太好了, 那能不能给我讲一讲呢?

小鱼:然后呢?

小屌丝:老地方~

小鱼:又是老地方,整的我都不好意思了。

小屌丝:这都是小事,我主要就想让你多放松放松…

小鱼:停,停, 打住~ 别说多了, 我们来聊discoart。

小屌丝:别着急啊,

小鱼:能不着急吗,你看,这都几点了, 再晚一会,就…

小屌丝:昂…

2、 代码实战

2.1 模块介绍

说起 discoart 可能大部分都不太了解。

但是,说到艺术库,可能你就有些印象了。

这里,我也引用官网对discoart的解析,让你对它有个初步的了解,如下:

DiscoArt is an elegant way of creating compelling Disco Diffusion[*] artworks for generative artists, AI enthusiasts and hard-core developers.
DiscoArt has a modern &
     professional API with a beautiful codebase, ensuring high usability and maintainability. It introduces handy features such as result recovery and persistence, gRPC/HTTP serving w/o TLS, post-analysis, easing the integration to larger cross-modal or multi-modal applications.

这里,我也简答的用汉语描述一下,即:

DiscoArt是一种优雅的方式,可以为生成艺术家,AI爱好者和铁杆开发人员创建引人注目的Disco Diffusion艺术品。
DiscoArt拥有现代和专业的API,具有漂亮的代码库,确保了高可用性和可维护性。它引入了方便的功能,例如结果恢复和持久性,没有TLS的gRPC / HTTP服务,后期分析,简化与更大的跨模态或多模态应用程序的集成。

简答一句话概括:DiscoArt就是为了艺术而生的。

2.2 模块安装

涉及到第三方库,肯定就需要安装

老规矩,pip 安装

pip install discoart

然后就是等待着安装。

其它安装方式,直接看这两篇:

  • Python3,选择Python自动安装第三方库,从此跟pip说拜拜!!
  • Python3:我低调的只用一行代码,就导入Python所有库!

安装的样子,如下:

这里提示一下:

  • 按照官网的要求, discoart的使用,必须依托于:Python 3.7+ 和 CUDA 的 PyTorch 。

2.3 代码示例

2.3.1 创建默认图片

这里直接使用discoart的 create方法即可

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    使用默认参数创建图片
'''
from discoart  import create
ca = create()

效果展示

2.3.2 设置参数创建图片

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    设置参数创建图片
'''
from discoart  import create
#设置参数
ca = create(
    text_prompts='A painting of sea cliffs in a tumultuous storm, Trending on ArtStation.',
    init_image='https://d2vyhzeko0lke5.cloudfront.net/xxxx7e77b72f0.png',
    skip_steps=100,
)

效果展示

2.3.3 查看设置参数

如果你忘记参数,也没关系,直接用cheatsheet 查询即可

代码展示

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    查看设置参数
'''
from discoart  import cheatsheet
#设置参数
sha = cheatsheet()

2.3.4 查看配置

如果要查看文档配置, 可以使用show_config:

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    查看文档配置
'''
from discorat import  show_config
# 展示第一个项目运行的配置
show_config(da)
# 参考第四个项目的运行配置
show_config(da[3])
#查看discoartID
show_config('discoart-xxxxfbf288')

2.3.5 保存配置

如果要保存文档配置, 可以使用save_config:

代码展示

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    保存文档配置
'''
from discoart import save_config
#保存第一次运行的配置
save_config(da, 'my.yml')  
#保存第四次运行的配置
save_config(da[3], 'my.yml')

2.3.6 加载配置

有了查看和保存,当然也可以直接加载配置文件了, 这里,使用load_config即可

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    加载文档配置
'''
from discoart import create, load_config
#加载配置文件
config = load_config('my.yml')
create(**config)

2.3.7 导出配置文件

为了便于后期的管理使用,同样可以直接导出配置文件为SVG映像,使用 save_config_svg方法:

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    导出配置文件为SVG映像
'''
from discoart.config import save_config_svg
#直接保存为svg映像
save_config_svg(da)

这里也展示一下, 保存的svg映像

2.3.8 生成Python代码

更神奇的功能,就是可以直接从配置中生成可运行的Python代码,使用export_python方法:

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    生成可运行的Python代码
'''
from discoart.config import export_python
export_python(da)

2.3.9 调用文档

如果你觉得自己配置太繁琐, 那可以直接使用DocumentArray作为初始状态运行。

代码示例

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    调用DocumentArray作为初始状态,运行
'''
from discoart import create
from docarray import DocumentArray
da = DocumentArray.pull('discoart-32xxx')
create(
    init_document=da[0],
    cut_ic_pow=0.5,
    tv_scale=600,
    cut_overview='[12]*1000',
    cut_innercut='[12]*1000',
    use_secondary_model=False,
)

当然, 如果你只想从已有的 DocArray ID 初始化, 那也不是不可能,

# -*- coding:utf-8 -*-
# @Time   : 2023-02-12
# @Author : Carl_DJ
'''
实现功能:
    从已有的 DocArray ID 初始化
'''
from discoart import create
create(init_document='discoart-320xxxx')

3、总结

看到这里, Doscart库的介绍就完成了。

按照流程, 我们来回顾一下今天都分享了啥内容:

  • 创建默认图片;
  • 设置参数创建图片;
  • 查看设置参数;
  • 查看文档配置;
  • 报错文档配置;
  • 加载文档配置;
  • 导出配置文件
  • 生成Python代码;
  • 调用文档;

你看, Doscoart也没有想想的那么难嘛, 常用的功能,也就差不多这么多。

所以, 只要我们把一个库从头到尾的捋一遍, 其实是很容易掌握的。

最后,唠叨一句:

我是奕然:

  • CSDN 博客专家;
  • 专家博主;
  • 51CTO 博客专家;
  • 51认证讲师;
  • 金牌面试官& 面试培训师

关注我,带你学习更多更有趣的Python知识。