Power Automation 上传文件到Blob

power apps内的设置

首先实现一个用于上传文件的控件

首先需要创建一个SharePoint List

里面不需要有太多的字段,只要把这个表创建出来就可以了给他一个名字(比如说我这里的list名称叫做”test“),然后点击刚刚创建的list再点击+New,你会发现,他下面有一个Attachment。如下图
比如说我这里的list名称叫做”test“
这个就成功了。然后我们再进行下一步。

power apps连接上SharePoint获取控件

回到Power Apps里,我们点击Edit Form加入一个控件。然后点击控件的Data Source属性,选择SharePoint连接器。然后找到刚刚创建的SharePoint list 连接上。在这里插入图片描述
如上图,我的list名称就叫做“附件”

对控件做处理,供我们使用

这个时候我们可以看到里面的字段都显示出来了
在这里插入图片描述
我们主要的是要Attachment,然后我们从左侧的Tree view中找到Attachment 复制出来,不用全复制只需要复制下图第三个就可以。在这里插入图片描述
这里我们放在了一个空白的屏幕中:
这时我们发现有错误,然后我们打开检查器。在这里插入图片描述
这个不用担心,错误是因为,这个控件没有了所依赖的父控件。点出来错误的,依次删除就可以了。然后我们可以尝试一下,点击Attach file我们发现可以打开本地文件夹,ok,这就成功了。然后我们可以对Attach做重命名或者大小调整等操作。

为文件上传准备power apps界面

现在我们准备好了上传的主控件,已经基本可以上传一张图片,因为我们今天主要是上传文件,更复杂一些,同样的上传图片也适用。上传图片和blob连接器可以见官网:微软官网示例

power automation设置

界面布局

1.我们现在插入一张image作为存储文件内容信息的。
2.我们可以把image的visible设为false。因为image只是存储文件信息并不需要展现出来。
3.然后我们还可以插入一个按钮,用于我们选中之后触发flow
总结: 现在我们总结一下界面上的布局,有一个attachment上传框(控件名称:File_Upload),有一个隐藏的image(控件名称:image9),有一个用于触发flow的按钮。

文件内容序列化以及上传

现在我们该设置一下控件上的内容,以下是按钮控件的Selected内容一部分

  UpdateContext(
        {
            varAttachmentcontrol: JSON(
                Image9.Image,
                JSONFormat.IncludeBinaryData
            )
        }
    );
    UpdateContext(
        {
            varBase64Only: Mid(
                varAttachmentcontrol,
                Find(
                    ",",
                    varAttachmentcontrol
                ) + 1,
                Len(varAttachmentcontrol) - Find(
                    ",",
                    varAttachmentcontrol
                ) - 1
            )
        }
    );

上面这一段代码就是在对文件内容(文件内容代码:Image9.Image)做JSON序列化处理。
我们上面说到image里面存储的是文件的内容。现在我们来看一下image的配置:
image9的image属性:

Last(File_Upload.Attachments).Value

总结: 现在image9通过 Last(File_Upload.Attachments).Value 与上传文件控件建立了连接。我们按钮的image9.image获取到image9的image内容进行序列化,也就是控件获取到了文件的内容进行了序列化。

flow上传文件到blob

现在power apps基本已经完成了,我们下一步就是flow的创建。我们来创建一个云端即时流:

我们先建一个参数向power apps ask 我们文件的内容。
在这里插入图片描述
我们文件的内容在power apps部分是json化的,所以在flow这里最好也转换一下,以免发生乱码。我们选择一个compose控件然后如下图箭头
在这里插入图片描述
然后我们需要把我们参数放在里面
在这里插入图片描述
如下图:
在这里插入图片描述
然后就开始我们正式的上传啦,我们再插入一个空间然后找到blob组
在这里插入图片描述

选择Create blob (V2),然后填入信息
在这里插入图片描述
下一步我们来创建一个URL,这个URL可以用于下载我们上传的文件
在这里插入图片描述

图中URL过期时间我设置为24h过期,这就是一个示例。还可以加天数,加秒 分。。。。具体可以看函数。
ok,很简单这样就可以上传到blob上了。我们来power apps这边来调用运行这个流。

UploadBlob.Run(
        varBase64Only   
    );

因为我们flow中就向power apps要了一个参数,这里就传一个参数。
最后还有一个很重要的事情。Createblob(V2)2的时候,其中有一项是让我们输入blob name,我们输入的文件名称后缀一定要和我们上传的文件名后缀一致,不然很有可能打不开。还有一个解决办法如下:
我们可以直接获取文件的名称(自动会带有后缀)然后我们直接用文件本身的名称。
flow中定义一个变量value同样向power apps ask 然后我们文件名那个地方直接用这个变量。
然后power apps要怎样获取文件名呢?如下代码

Last(File_Upload.Attachments).Name

这时我们就需要在运行流时多加一个参数

UploadBlob.Run(
        varBase64Only,
        Last(File_Upload.Attachments).Name 
    );

上传按钮的全部代码:

 UpdateContext(
        {
            varAttachmentcontrol: JSON(
                Image9.Image,
                JSONFormat.IncludeBinaryData
            )
        }
    );
    UpdateContext(
        {
            varBase64Only: Mid(
                varAttachmentcontrol,
                Find(
                    ",",
                    varAttachmentcontrol
                ) + 1,
                Len(varAttachmentcontrol) - Find(
                    ",",
                    varAttachmentcontrol
                ) - 1
            )
        }
    );
    UploadBlob.Run(
        varBase64Only
    );

注意两点:
1.参数的顺序问题,我们可以点击flow进行手动测试查看参数变量的顺序,然后再power apps上对应顺序输入参数值。
2.Azure Blob中如果文件名相同,则会覆盖旧的文件,所以这里建议重新定义文件名可以用字符拼接,年月日+文件名+后缀。 例:202302161130filetest.csv(和正常文件名都一样,可以加下划线)

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小松很努力

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值