码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 用户权限数据转换为用户组列表(3/3) - Excel PY公式


    最近Excel圈里的大事情就是微软把PY塞进了Excel单元格,可以作为公式使用,轻松用PY做数据分析。系好安全带,老司机带你玩一把。

    请添加图片描述

    实例需求:如下是AD用户的列表,每个用户拥有该应用程序的只读或读写权限,现在需要创建新的AD用户组,并根据用户当前的权限,将这些用户添加到相应的组中。

    当前数据集:

    SafeUserNameRead permissionsRW permissions
    Safe1User1YesYes
    Safe1User2YesNo
    Safe1User3YesYes
    Safe1User4YesNo
    Safe2User1YesYes
    Safe2User2YesNo
    Safe2User3YesYes
    Safe2User4YesNo

    整理后输出数据集:

    SafeADGroup Userlist
    Safe1Safe1-ReadGroupUser1,User2,User3,User4
    Safe1Safe1-RWGroupUser1,User3
    Safe2Safe2-ReadGroupUser1,User2,User3,User4
    Safe2Safe2-RWGroupUser1,User3
    df=xl("Table1[#全部]", headers=True)
    rw_df = df[df['RW permissions'] == 'Yes'].drop(columns=['RW permissions'])
    grp_rw = rw_df.groupby(['Safe'])['UserName'].apply(','.join).reset_index()
    grp_rw['AD Group'] = grp_rw['Safe'] + '-RWGroup'
    r_df = df[df['Read permissions'] == 'Yes'].drop(columns=['Read permissions'])
    grp_r = r_df.groupby(['Safe'])['UserName'].apply(','.join).reset_index()
    grp_r['AD Group'] = grp_r['Safe'] + '-ReadGroup'
    df_output = pd.concat([grp_r, grp_rw], axis=0).rename(columns={'UserName': 'UserList'})[['Safe', 'AD Group', 'UserList']]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    【代码解析】
    第1行代码读取Excel表作为DataFrame。
    第2行代码过滤写权限为Yes的行。
    第3行代码分组并合并UserName列。
    第4行代码添加分组名称列。
    第5行代码过滤读权限为Yes的行。
    第6行代码分组并合并UserName列。
    第7行代码添加分组名称列。
    第8行代码合并读写两个DataFrame。
    第9行代码重命名列并选择需要的列。

    在这里插入图片描述

    小结:
    Python的Pandas库可以便捷地处理Excel表数据。通过filter和groupby可以进行分组,concat可以实现表连接,apply方法可以在分组上执行操作,生成自定义列。


    相关系列博文链接:

    用户权限数据转换为用户组列表(1/3) - VBA
    用户权限数据转换为用户组列表(2/3) - Power Query
    用户权限数据转换为用户组列表(3/3) - Excel PY公式

  • 相关阅读:
    仪表板支持水印设置,数据集新增脱敏规则支持,DataEase开源数据可视化分析平台v1.17.0发布
    FlexRay网络管理与测试
    nginx配置https 访问
    leetcode 977有序数组的平方(附容器未初始化的问题)
    枚举与接口常量、类常量有什么区别?
    <位图(bitset)和布隆过滤器(BloomFilter)>——《C++高阶》
    前端uniapp生成海报绘制canvas画布并且保存到相册【实战/带源码/最新】
    Git错误:Incorrect username or password (access token)
    DbSchema导出HTML/PDF版表结构
    Linux进程通信:命名管道,System V共享内存
  • 原文地址:https://blog.csdn.net/taller_2000/article/details/132787246
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号