首页 文章 精选 留言 我的

精选列表

搜索[快速入门],共10000篇文章
优秀的个人博客,低调大师

用Python快速将任意文件转为PDF

**痛点:** 相信大家都会遇到一种**场景**。老师/上司要求你把**某个文件转为pdf**,并且是一批(不止一个,一个的话手动就可以搞定),并且这种是枯燥无聊的工作,既没有什么技术含量又累。 试想一下,如果我把这些文件**放到一个文件夹下,执行一下程序**,几分钟后这些文件就转好。这样半天的活,只要**花几分钟就解决**了。岂不是美滋滋!!! 今天辰哥就教大家将任意文件批量转为PDF,这里以日常办公的**word**、**excel**、**ppt**为例,这三种格式的文件转为PDF。 # 01、word转PDF 这里借助Python的docx2pdf去完成转换操作,该库的安装命令如下: ```python pip install docx2pdf ``` **目标**:读取文件夹下的全部word文件,然后进行转换,最后保存到对应的文件夹中。 ![](https://oscimg.oschina.net/oscnet/up-aaad299d732187c30ab9bb969ad8b663c9e.png) 这里辰哥新建两个word文件作为演示,打开其中一个word看看 ![](https://oscimg.oschina.net/oscnet/up-5d82795951ab0e2affa86b21e5e69758f2b.png) 里面不仅有文字,同时包含有图片 ```python import os from docx2pdf import convert word_path = 'word_path' word_to_pdf = 'word_to_pdf' for i,j,name in os.walk(word_path): for word_name in name: convert(word_path+"/"+word_name, word_to_pdf+"/"+word_name.replace("docx","pdf")) ``` 其中word\_path是存放word文件的文件夹,word\_to_pdf是转换后的pdf存放文件夹。 ![](https://oscimg.oschina.net/oscnet/up-c4411ac499e8d75475033d86c02c569987f.png) 打开第一个pdf,内容如下: ![](https://oscimg.oschina.net/oscnet/up-f90f62a5e95fa32df6cb77022e394d5a9a0.png) 可以看到**文字**、**图片**、以及**排版****这些**都与原文件(word)**一模一样**。 # 02、excel转PDF 这里需要使用到的库是comtypes,下面直接上案例。 上面的word转pdf已经教大家学会了从文件夹中读取全部的文件,所有这里同样的就不再赘述。 ```python pip install pywin32 ``` **目标:** 将excel文件转为PDF ![](https://oscimg.oschina.net/oscnet/up-62f1d3f624d4d77b35002936b233b3f1502.png) 这里辰哥新建一个excel文件作为演示 ```python import os from win32com.client import DispatchEx excel_path = "D:/公众号/0626/Python研究者.xls" pdf_path = "D:/公众号/0626/Python研究者.pdf" xlApp = DispatchEx("Excel.Application") xlApp.Visible = False xlApp.DisplayAlerts = 0 books = xlApp.Workbooks.Open(excel_path,False) books.ExportAsFixedFormat(0, pdf_path) books.Close(False) xlApp.Quit() ``` 运行之后生成pdf文件 ![](https://oscimg.oschina.net/oscnet/up-2e821918e98d78913925026e435585ef9cf.png) 打开pdf ![](https://oscimg.oschina.net/oscnet/up-24b5b0a4d23dfa4ba12ef8cdc870d9607f9.png) 可以看到excel中的数据已经全部转为PDF格式。 # 03、ppt转PDF 这里需要使用到的库是comtypes,下面直接上案例。 上面的word转pdf已经教大家学会了从文件夹中读取全部的文件,所有这里同样的就不再赘述。 **目标**:ppt转为pdf ![](https://oscimg.oschina.net/oscnet/up-6a60d897b25ec6470f7d57323d527559795.png) 这个是辰哥之前做分享时弄的一个ppt,咱们就以这个ppt为例 ```python import comtypes.client import os def ppt_to_pdf(): #设置路径 input_file_path=os.path.abspath("Python学习规划路线.pptx") output_file_path=os.path.abspath("Python学习规划路线.pdf") #创建PDF powerpoint=comtypes.client.CreateObject("Powerpoint.Application") powerpoint.Visible=1 slides=powerpoint.Presentations.Open(input_file_path) #保存PDF slides.SaveAs(output_file_path,32) slides.Close() ``` 这里将会ppt:**Python学习规划路线.pptx**转为**Python学习规划路线.pdf** ![](https://oscimg.oschina.net/oscnet/up-3b36a79412b14b169d38fddc36555c46818.png) 打开pdf其内容如下: ![](https://oscimg.oschina.net/oscnet/up-9e1326514d5ff570cd0586605ab1c6eaf5b.png) # 04、小结 本文基本就成功实现目标要求,从效果来看还是非常不错的!完整源码可由文中代码组合而成(已全部分享在文中),感兴趣的读者可以自己尝试! 一定要**动手尝试** **!**一定要**动手尝试** **!**一定要**动手尝试!**

优秀的个人博客,低调大师

Unity平台 | 快速集成华为AGC云数据库服务

1、环境与应用信息 版本名称 集成环境 测试设备 agconnect-database:1.2.3.301 Unity 2019.4.17f1c1 荣耀magic2 OPPO Reno2 AGC地址:https://developer.huawei.com/consumer/cn/service/josp/agc/index.html 2、Unity环境准备: 官方文档: https://docs.unity.cn/cn/Packages-cn/com.unity.huaweiservice@1.3/manual/clouddb.html 1、 下载Unity Hub,安装Unity https://unity.cn/releases。 下载安装就不详细介绍了。 2、 Android环境配置:可参考如下截图 3、导入HuaweiServices的Package包: 在Assect Store中搜索Huawei Services, 找到AGC的包,然后点击Import,导入相应的包。 3、AGC环境配置 1、配置华为AGC上的参数:回到AGC控制台:找到之前创建的App: https://developer.huawei.com/consumer/cn/service/josp/agc/index.html 2、选择:我的项目-> 构建 – 云数据库 点击开通,开通云数据库,然后根据华为文档要求,创建对象类型和存储区 https://developer.huawei.com/consumer/cn/doc/development/AppGallery-connect-Guides/agc-clouddb-get-started#h1-1594006870043-0 在对象类型页签,点击新增,新增一个名为BookInfo的对象类型,配置如下: 在存储区页面,点击新增,新增一个名为QuickStartDemo的存储区 3、服务开通以后,回到项目设置界面,下载最新的json文件。在我的项目-项目设置-常规-应用下,点击agconnect-services.json下载 将刚下载好json文件,放到Unity项目Assets / Plugins / Android目录下: 4、设置Android环境: 1、在Player-Publish Setting中启用Android的自定义清单和gradle 2、在Other Setting中配置包名:注意需要和AG官网的包名保持一致: 3、配置项目级gradle,此处对应Assets\Plugins\Android路径下的baseProjectTmeplate.gradle文件,添加如下内容 allprojects { buildscript { repositories { maven { url 'https://developer.huawei.com/repo/' } } } dependencies { classpath 'com.android.tools.build:gradle:3.4.0' classpath 'com.huawei.agconnect:agcp:1.4.2.301' **BUILD_SCRIPT_DEPS** } } repositories { maven { url 'https://developer.huawei.com/repo/' } } } 4、配置应用级gradle,此处对应Assets\Plugins\Android路径下的LauncherTmeplate.gradle文件,添加如下内容: apply plugin: 'com.android.application' apply plugin: 'com.huawei.agconnect' dependencies { implementation project(':unityLibrary') implementation 'com.android.support:appcompat-v7:28.0.0' implementation 'com.huawei.agconnect:agconnect-core:1.2.0.300' implementation "com.huawei.agconnect:agconnect-database:1.2.3.301" } 5、回到AGC界面,导出对象类型文件: 1、点击“导出”,选择json,将json文件导出到Unity项目Assets / Plugins / Android目录下 2、点击“导出”,选择java,选择“Android”,配置包名,将zip文件导出并且解压到Unity项目Assets / Plugins / Android目录下 6、生成CloudDB文件: 在Unity中,点击菜单栏的CloudDB Kit - > CloudDB Settting 相应的配置如下: 1、 JavaCode Package Name:配置导出java文件时配置的包名 2、 ObjectType JsonFile Path:选择对应导出的json文件:例如我的路径为‘Assets/Plugins/Andriod/model.json’ 3、 Namespace:生成的C# 文件所用的namespace 4、 Export Path:导出的C# 文件的存放路径 5、从零开发云数据库功能 1、点击GameObject- UI –Button, 创建几个按钮: 点击按钮,然后在右侧选择 Add Component, 创建并且添加一个Script文件。对应的界面布局如下: 2、代码前置与集成准备: using System; using System.Collections; using UnityEngine; using HuaweiService; using HuaweiService.CloudDB; using HuaweiService.Auth; using HuaweiServiceDemo; public class testDBDemo : MonoBehaviour { private static AGConnectCloudDB mCloudDB; private static CloudDBZone mCloudDBZone; private static CloudDBZoneConfig mConfig; private static CloudDBZoneQuery mQuery; private const string mClouudDBZoneName = "QuickStartDemo"; private const string bookInfoClass = "com.huawei.agc.clouddb.quickstart.model.BookInfo"; private const string testAllClass = "com.huawei.agc.clouddb.quickstart.model.TestAll"; private static CloudDBZoneObjectList<BookInfo> mObjectList = new CloudDBZoneObjectList<BookInfo> (); // 成功回调 public delegate void SuccessCallBack<T>(T o); public class HmsSuccessListener<T>:OnSuccessListener{ public SuccessCallBack<T> CallBack; public HmsSuccessListener(SuccessCallBack<T> c){ CallBack = c; } public void onSuccess(T arg0) { Debug.Log("OnSuccessListener onSuccess"); if(CallBack != null) { CallBack.Invoke(arg0); } } public override void onSuccess(AndroidJavaObject arg0){ Debug.Log("OnSuccessListener onSuccess"); if(CallBack !=null) { Type type = typeof(T); IHmsBase ret = (IHmsBase)Activator.CreateInstance(type); ret.obj = arg0; CallBack.Invoke((T)ret); } } } // 失败回调 public delegate void FailureCallBack(HuaweiService.Exception e); public class HmsFailureListener : OnFailureListener { public FailureCallBack CallBack; public HmsFailureListener(FailureCallBack c) { CallBack = c; } public override void onFailure(HuaweiService.Exception arg0) { if (CallBack != null) { CallBack.Invoke(arg0); } } } // Start is called before the first frame update void Start() { login(); } // Update is called once per frame void Update() { } } 3、集成认证服务:此处为方便使用,集成匿名认证 public void login() { AGConnectAuth auth = AGConnectAuth.getInstance(); auth.signInAnonymously().addOnSuccessListener(new HuaweiOnsuccessListener<SignInResult>((signresult) => { Debug.Log("sign in successfully." + signresult.getUser().getUid()); })).addOnFailureListener(new HuaweiOnFailureListener((e) => { Debug.Log("sign in failed"); })); } 6、集成云数据库接口 1、始化以及创建对象类型 public void CreateObjectType() { AGConnectCloudDB.initialize(new Context()); mCloudDB = AGConnectCloudDB.getInstance(); Debug.Log("CloudDBInstance: " + mCloudDB); try { mCloudDB.createObjectType(ObjectTypeInfoHelper.getObjectTypeInfo()); Debug.Log("createObjectType:" + mCloudDB ); } catch (System.Exception e) { Debug.Log("createObjectType: " + e.Message); } } 2、openCloudZOne,打开存储区 public void OpenCloudDBZone() { // Debug.Log("Start OpenCloudDBZone:" + mCloudDB ); mConfig = new CloudDBZoneConfig("QuickStartDemo", CloudDBZoneConfig.CloudDBZoneSyncProperty.CLOUDDBZONE_CLOUD_CACHE, CloudDBZoneConfig.CloudDBZoneAccessProperty.CLOUDDBZONE_PUBLIC); mConfig.setPersistenceEnabled(true); Task openDBZoneTask = mCloudDB.openCloudDBZone2(mConfig, true); openDBZoneTask.addOnSuccessListener(new HmsSuccessListener<CloudDBZone>((cloudDBZone) => { mCloudDBZone = cloudDBZone; Debug.Log("open clouddbzone2 success"); })) .addOnFailureListener(new HmsFailureListener((HuaweiService.Exception e) => { Debug.Log("open clouddbzone2 failed " + e.toString()); })); } 3、插入数据 public void upsertBookInfo(){ if (mCloudDBZone == null) { Debug.Log("CloudDBZone is null, try re-open it"); return; } var bookInfo = new BookInfo { Id = 4, BookName = "test4" }; Task task = mCloudDBZone.executeUpsert(bookInfo); task.addOnSuccessListener(new HmsSuccessListener<int>((cloudDBZoneResult) => { Debug.Log("upsert " + cloudDBZoneResult + " records"); })) 4. 查询与处理数据并展示 public void testQueryInfo () { mQuery = CloudDBZoneQuery.where (new AndroidJavaClass (bookInfoClass)).equalTo ("shadowFlag", true); if (mCloudDBZone == null || mQuery == null) { Debug.Log("CloudDBZone or CloudDBZoneQuery is null, try re-open it"); return; } Task queryTask = mCloudDBZone.executeQuery (mQuery, CloudDBZoneQuery.CloudDBZoneQueryPolicy.POLICY_QUERY_FROM_CLOUD_ONLY); queryTask.addOnSuccessListener (new HmsSuccessListener<CloudDBZoneSnapshot<BookInfo>> ((snapshot) => { processQueryResult (snapshot); })) .addOnFailureListener (new HmsFailureListener ((exception) => { Debug.Log ("Query book list from cloud failed: " + exception.toString ()); })); } private void processQueryResult (CloudDBZoneSnapshot<BookInfo> snapshot) { mObjectList = snapshot.getSnapshotObjects (); List<BookInfo> bookInfoList = new List<BookInfo> (); try { string result = ""; while (mObjectList.hasNext ()) { BookInfo bookInfo = mObjectList.next (); bookInfoList.add (bookInfo); result += $"{bookInfo.BookName} "; } Debug.Log ($"QueryResult: {result}"); } catch (System.Exception e) { Debug.Log ($"QueryResult : {e.Message}"); } finally { snapshot.release (); } } 7、打包测试 1、 点击File – Build and setting,进入打包页面,在该页面切换Android Platform。 2、 选择好对应的设备以后,点击 Build And Run 3、 然后就可以再Android的 Logcat 中,查看Unity的相关日志。 其中,插入和删除数据都可以在AGC界面查看到。 欲了解更多详情,可参考: 云数据库Demo:https://github.com/AppGalleryConnect/agc-demos/tree/main/Android/agc-clouddb-demo-java 原文链接:https://developer.huawei.com/consumer/cn/forum/topic/0203465380835350101?fid=0101271690375130218 原作者:Mayism

资源下载

更多资源
Mario

Mario

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Spring

Spring

Spring框架(Spring Framework)是由Rod Johnson于2002年提出的开源Java企业级应用框架,旨在通过使用JavaBean替代传统EJB实现方式降低企业级编程开发的复杂性。该框架基于简单性、可测试性和松耦合性设计理念,提供核心容器、应用上下文、数据访问集成等模块,支持整合Hibernate、Struts等第三方框架,其适用范围不仅限于服务器端开发,绝大多数Java应用均可从中受益。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册