首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >powershell csv循环PSCustomObject

powershell csv循环PSCustomObject
EN

Stack Overflow用户
提问于 2021-05-10 23:12:10
回答 1查看 34关注 0票数 1

我正在尝试迭代VM名称并将它们存储在PSCustomObject中,并在输出中按顺序分配一个子网,如下所示: VM1 Subnet1 VM2 Subnet2 VM3 Subnet3 VM4 Subnet1 VM5 Subnet2 How to output。

代码语言:javascript
复制
$csv = import-csv C:\ps\sample.csv
$myobject = foreach ($line in $csv){
    if ($line.count -gt 0) {
        for($i = 0; $i -lt $line.count; $i++){
            $count = $i + 1
                [pscustomobject]@{
                VMName = $line.vmname+$count
                Subnet = $line.subnet -split ',' | Get-Random
                Sku    = $line.sku
                os     = $line.os
                }
            }
        }
    }
$myobject

谢谢!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-05-10 23:40:48

下面的代码完成以下工作:

代码语言:javascript
复制
$csv = import-csv C:\ps\sample.csv -Delimiter ';'
$myobject = foreach ($line in $csv){
    if ($line.count -gt 0) {
        for($i = 0; $i -lt $line.count; $i++){
            $ar_sub = $line.subnet -split ','
            $l_sub = $ar_sub.count

                [pscustomobject]@{
                VMName = $line.vmname+$count
                Subnet = $ar_sub[$i % $l_sub]
                Sku    = $line.sku
                os     = $line.os
                }
            }
        }
    }
$myobject

结果:

代码语言:javascript
复制
VMName Subnet  Sku      os    
------ ------  ---      --    
appvm1 subnet1 t2.mciro centos
appvm2 subnet2 t2.mciro centos
appvm3 subnet3 t2.mciro centos
appvm4 subnet1 t2.mciro centos
appvm5 subnet2 t2.mciro centos
dbvm1  subnet4 t3.micro centos
dbvm2  subnet5 t3.micro centos
dbvm3  subnet6 t3.micro centos
dbvm4  subnet4 t3.micro centos
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67473045

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档